/* Base theme rules moved to theme.css */

@font-face {
  font-family: "amino-regular-13";
  src: url("../fonts/Amino Bold.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
}

.insight-logo,
.hpgb-logo,
.hero-logo {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.hpgb-logo {
  width: auto;
}

@media (min-width: 1980px) {
  .insight-logo {
    width: 8vw;
  }

  .hpgb-logo {
    height: 3vw;
  }

  .hpgb-name {
    font-size: 0.7vw;
  }

  .hpgb-name {
    font-size: 0.7vw;
  }

  .hpgb-type {
    font-size: 0.45vw;
  }

  .hpgb-sponsor {
    font-size: 0.45vw;
  }
}

@media (max-width: 1980px) {
  .figurecaption {
    font-size: 0.74vw;
    white-space: nowrap;
  }

  .insight-logo {
    width: 14vw;
  }

  .hpgb-logo {
    height: 5vw;
  }

  .hpgb-name {
    font-size: 1.05vw;
    padding-bottom: 7px;
  }

  .hpgb-type {
    font-size: 0.75vw;
    padding-bottom: 7px;
  }

  .hpgb-sponsor {
    font-size: 0.75vw;
  }
}

@media (max-width: 1440px) {
  .figurecaption {
    font-size: 0.9vw;
    white-space: nowrap;
  }

  .insight-logo {
    width: 15vw;
  }

  .hpgb-logo {
    height: 5vw;
  }

  .hpgb-name {
    font-size: 1.2vw;
    padding-bottom: 2px;
  }

  .hpgb-type {
    font-size: 0.9vw;
    padding-bottom: 2px;
  }

  .hpgb-sponsor {
    font-size: 0.9vw;
  }
}

/* Chairman desk */
.cm-card {
  border: 1px solid #e7ecf3;
  border-radius: 1rem;
  background: #ffffff;
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.04);
}

.cm-badge {
  background: #f5f7fa;
  border: 1px solid #e7ecf3;
  border-radius: 0.75rem;
  padding: 6px 12px;
  font-size: 0.85rem;
}

.cm-hero-name {
  font-weight: 700;
  font-size: 1.1rem;
  color: #1f2a44;
  margin-bottom: 2px;
  text-transform: uppercase;
}

.cm-hero-title {
  color: #6c757d;
  font-size: 0.9rem;
  margin-bottom: 0;
}

.cm-hero-wrap {
  width: 100%;
  height: auto;
  max-height: none;
}

.cm-hero-img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 20px;
}

@media (max-width: 1366px) {
  .figurecaption {
    font-size: 0.9vw;
    white-space: nowrap;
  }

  .insight-logo {
    width: 16vw;
  }

  .hpgb-logo {
    height: 5.3vw;
  }

  .hpgb-name {
    font-size: 1.3vw;
    padding-bottom: 2px;
  }

  .hpgb-type {
    font-size: 0.9vw;
    padding-bottom: 2px;
  }

  .hpgb-sponsor {
    font-size: 0.9vw;
  }
}

@media (max-width: 1280px) {
  .figurecaption {
    font-size: 0.8vw;
    white-space: nowrap;
  }

  .insight-logo {
    width: 17vw;
  }

  .hpgb-logo {
    height: 6vw;
  }

  .hpgb-name {
    font-size: 1.3vw;
    padding-bottom: 5px;
  }

  .hpgb-type {
    font-size: 0.9vw;
    padding-bottom: 5px;
  }

  .hpgb-sponsor {
    font-size: 0.9vw;
  }
}

@media (max-width: 1024px) {
  .figurecaption {
    font-size: 0.7vw;
    white-space: nowrap;
  }

  .insight-logo {
    width: 19vw;
  }

  .hpgb-logo {
    height: 7vw;
  }

  .hpgb-name {
    font-size: 1.4vw;
  }

  .hpgb-type {
    font-size: 0.9vw;
  }

  .hpgb-sponsor {
    font-size: 0.9vw;
  }
}

@media (max-width: 912px) {
  .figurecaption {
    font-size: 1.74vw;
    white-space: nowrap;
  }
}

@media (max-width: 911px) {
  .figurecaption {
    font-size: 2.74vw;
    white-space: nowrap;
  }
}

.view:hover {
  background-color: var(--color-dark);
  transition: ease 0.6s;
  color: white;
  box-shadow: 0 0 7px var(--color-dark);
  border: 1px solid var(--color-border);
}

/* ALTCHA widget styled to match Insight design language */
.altcha-theme-wrapper {
  display: block;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 30%, white);
  border-radius: 12px;
  background: linear-gradient(180deg, #ffffff 0%, var(--color-surface) 100%);
  box-shadow: 0 8px 24px rgba(16, 104, 178, 0.08);
  position: relative;
  overflow: hidden;
}

.altcha-theme-wrapper::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
}


.altcha-theme-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.altcha-theme-label i {
  color: var(--color-accent);
}

.altcha-theme-copy {
  margin: 0 0 10px 0;
  font-size: 0.84rem;
  line-height: 1.35;
  color: var(--color-muted);
}

.altcha-theme-body {
  position: relative;
  min-height: 64px;
  padding: 10px 132px 10px 10px;
  border-radius: 2px;
  border: 1px solid #c8c8c8;
  background: #f1f1f1;
}


.altcha-theme-wrapper:focus-within {
  border-color: rgba(16, 104, 178, 0.45);
  box-shadow: 0 0 0 3px rgba(16, 104, 178, 0.18);
}






.altcha-theme-widget {
  display: block;
  width: 100%;
  min-height: 40px;
  --altcha-max-width: 100%;
  --altcha-border-width: 0px;
  --altcha-border-color: transparent;
  --altcha-border-radius: 0px;
  --altcha-background-color: transparent;
  --altcha-color-primary: #2f9254;
  --altcha-color-success: #2f9254;
  --altcha-font-family: "Roboto", sans-serif;
  --altcha-color-text: #121212;
}

.altcha-theme-widget::part(container) {
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.altcha-branding {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  pointer-events: none;
}

.altcha-branding-logo {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.altcha-branding-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.altcha-branding-title {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #1d1d1d;
  font-weight: 700;
}

.altcha-branding-links {
  font-size: 9px;
  color: #6d6d6d;
}

@media (max-width: 480px) {
  .altcha-theme-body {
    padding-right: 112px;
  }
  .altcha-branding-logo {
    width: 16px;
    height: 16px;
  }
  .altcha-branding-title {
    font-size: 9px;
  }
}

.small-card {
  background-color: white;
  border: 1px solid var(--color-border);
  color: var(--color-muted) !important;
  height: 100px;
  font-size: 16px;
  padding-top: 13px;
  padding-bottom: 10px;
  margin-bottom: 20px;
  border-radius: 3px;
}

.small-card:hover {
  background-size: cover;
  background-position: center;
  background-image: url(../assets/makerShadeHover.jpg);
  background-image: image-set(url(../assets/makerShadeHover.jpg.webp) type("image/webp"), url(../assets/makerShadeHover.jpg) type("image/jpeg"));
  transition: ease 0.6s;
  color: #ffffff !important;
  box-shadow: 0 0 7px var(--color-dark);
  border: 1px solid var(--color-border);
}


/*---scroll---*/

@-webkit-keyframes scroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(calc(-250px * 7));
  }
}

@keyframes scroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(calc(-250px * 7));
  }
}

.slider {
  background: white;
  height: 100px;
  margin: auto;
  overflow: hidden;
  position: relative;
  width: 50%;
}

.slider::before,
.slider::after {
  content: "";
  height: 100px;
  position: absolute;
  width: 200px;
}

.slider::after {
  right: 0;
  top: 0;
  transform: rotateZ(180deg);
}

.slider::before {
  left: 0;
  top: 0;
}

.slider .slide-track {
  -webkit-animation: scroll 40s linear infinite;
  animation: scroll 40s linear infinite;
  display: flex;
  width: calc(250px * 14);
}

.slider .slide {
  height: 100px;
  width: 250px;
}

.news-reel {
  background: transparent;
  padding: 0;
  border: 0;
}

.breaking-news {
  background: linear-gradient(135deg, #0f2f5c 0%, #0d5a98 50%, #1068b2 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 0;
  box-shadow: 0 12px 28px rgba(16, 104, 178, 0.25);
  overflow: hidden;
  backdrop-filter: blur(6px);
}

.breaking-news .news {
  min-width: 120px;
  background: #50b748;
  color: #ffffff;
  border-right: 1px solid rgba(0, 0, 0, 0.08);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 18px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.22) inset;
  backdrop-filter: blur(4px);
}

.news-scroll {
  background: transparent;
  color: #eaf3ff;
  padding-left: 8px;
}

.news-scroll span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 18px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.news-scroll a {
  color: #eaf3ff;
  text-decoration: none;
}

.news-scroll a:hover {
  color: #b4d7ff;
  text-decoration: none;
}

.scroll a {
  color: #000000;
}

.scroll a:hover {
  color: #0d5a98;
}

.scroll {
  color: #000000;
}

.dot {
  height: 6px;
  width: 6px;
  margin-left: 3px;
  margin-right: 3px;
  margin-bottom: 2px !important;
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  display: inline-block;
}

/*
 * Container - Button
 */
.float {
  position: fixed;
  width: 60px;
  height: 60px;
  bottom: 20px;
  right: 20px;
  border-radius: 50px;
  text-align: center;
  z-index: 1000;
  animation: bot-to-top 2s ease-out;
}

/* Hidden Buttons */
a.float + ul {
  visibility: hidden;
}

/* Visible Buttons */
a.float:hover + ul {
  visibility: visible;
  animation: scale-in 0.5s;
}

/* Center icons */
a i.icon {
  font-size: 24px;
  margin-top: 18px;
  color: #fff;
}

a i.icons {
  font-size: 24px;
  margin-top: 18px;
  color: var(--color-primary);
}

/*
 * Animations
 */
a.float i {
  animation: rotate-in 0.5s;
}

a.float:hover > i {
  animation: rotate-out 0.5s;
}

@keyframes bot-to-top {
  0% {
    bottom: -60px;
  }

  50% {
    bottom: 40px;
  }
}

@keyframes scale-in {
  from {
    transform: scale(0);
    opacity: 0;
  }

  to {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes rotate-in {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes rotate-out {
  from {
    transform: rotate(360deg);
  }

  to {
    transform: rotate(0deg);
  }
}

@media only screen and (max-width: 766px),
  (min-device-width: 768px) and (max-device-width: 766px) {
	.latest {
		--latest-accent: var(--color-primary);
		--latest-ink: var(--color-dark);
		--latest-line: var(--color-border);
		--latest-soft: var(--color-surface);
		--latest-label-width: 30%;
		--latest-label-gap: 20px;
		display: block;
	}

  .latest table,
  .latest thead,
  .latest tbody,
  .latest th,
  .latest td,
  .latest tr {
    display: block;
  }

  .latest th {
    display: none;
  }

  .latest thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }

  .latest tr {
    margin: 0 0 0.65rem 0;
    border: 1px solid var(--latest-line);
    border-radius: 16px;
    background: transparent;
    box-shadow: 0 10px 20px rgba(16, 104, 178, 0.1);
    overflow: hidden;
  }

  .latest tr:nth-child(odd) {
  }

  .latest td {
    border: none;
    position: relative;
    padding: 10px 14px 0 calc(var(--latest-label-width) + var(--latest-label-gap));
    min-height: 2.6rem;
    text-align: right;
    background-color: transparent;
    border-bottom: 1px dashed var(--latest-soft);
    color: var(--latest-ink);
    font-weight: 600;
  }

  .latest td:last-child {
    border-bottom: none;
  }

  .latest td:before {
    position: absolute;
    top: 0.6rem;
    left: 12px;
    width: var(--latest-label-width);
    padding: 4px 8px;
    white-space: nowrap;
    line-height: 1.2;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--latest-accent);
    text-align: left;
    background: rgba(16, 104, 178, 0.08);
    border-radius: 999px;
  }

  .latest td:nth-of-type(1):before {
    content: "Sr. No.";
    font-weight: bold;
  }

  .latest td:nth-of-type(2):before {
    content: "Department";
    font-weight: bold;
  }

  .latest td:nth-of-type(3):before {
    content: "Circular Number";
    font-weight: bold;
  }

  .latest td:nth-of-type(4):before {
    content: "Date";
    font-weight: bold;
  }

  .latest td:nth-of-type(5):before {
    content: "Particulars";
    font-weight: bold;
  }

  .latest td:nth-of-type(6):before {
    content: "Download Link";
    font-weight: bold;
  }

  .latest td a {
    font-weight: 700;
    color: var(--latest-accent);
  }

  #example_length label {
    display: flex;
    margin-bottom: 10px;
  }

  #example_length .form-select {
    margin-left: 7px;
    margin-right: 7px;
    width: 74px;
  }

  #example_filter label {
    display: flex;
    float: left;
    margin-bottom: 10px;
  }

  #example_filter .form-control {
    margin-left: 10px;
    width: 100%;
  }

  #example_info {
    margin-bottom: 10px;
  }

  .tables table {
    display: block;
  }

  .tables thead {
    display: block;
  }

  .tables tbody {
    display: block;
  }

  .tables th {
    display: block;
  }

  .tables td {
    display: block;
  }

  .tables tr {
    display: block;
  }

  .tables th {
    display: none;
  }

  .tables thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }

  .tables tr {
    margin: 0 0 1rem 0;
    border-left: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
  }

  .tables tr:nth-child(odd) {
  }

  .tables td {
    border: none;
    position: relative;
    padding-left: 45%;
    text-align: left;
    background-color: var(--color-surface);
  }

  .tables td:before {
    position: absolute;
    top: 5;
    left: 6px;
    width: 40%;
    padding-right: 10px;
    white-space: nowrap;
  }

  .tables td:nth-of-type(1):before {
    content: "Sr. No.";
    font-weight: bold;
  }

  .tables td:nth-of-type(2):before {
    content: "Circular Number";
    font-weight: bold;
  }

  .tables td:nth-of-type(3):before {
    content: "Particulars";
    font-weight: bold;
  }

  .tables td:nth-of-type(4):before {
    content: "Download Link";
    font-weight: bold;
  }

  #example_length label {
    display: flex;
    margin-bottom: 10px;
  }

  .list {
    --list-accent: var(--color-primary);
    --list-ink: var(--color-dark);
    --list-line: var(--color-border);
    --list-soft: var(--color-surface);
    --list-label-width: 30%;
    --list-label-gap: 20px;
    display: block;
  }

  .list table,
  .list thead,
  .list tbody,
  .list th,
  .list td,
  .list tr {
    display: block;
  }

  .list th {
    display: none;
  }

  .list thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }

  .list tr {
    margin: 0 0 0.65rem 0;
    border: 1px solid var(--list-line);
    border-radius: 16px;
    background: transparent;
    box-shadow: 0 10px 20px rgba(16, 104, 178, 0.1);
    overflow: hidden;
  }

  .list tr:nth-child(odd) {
  }

  .list td {
    border: none;
    position: relative;
    padding: 10px 14px 0 calc(var(--list-label-width) + var(--list-label-gap));
    min-height: 2.6rem;
    text-align: right;
    background-color: transparent;
    border-bottom: 1px dashed var(--list-soft);
    color: var(--list-ink);
    font-weight: 600;
  }

  .list td:last-child {
    border-bottom: none;
  }

  .list td:before {
    position: absolute;
    top: 0.6rem;
    left: 12px;
    width: var(--list-label-width);
    padding: 4px 8px;
    white-space: nowrap;
    line-height: 1.2;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--list-accent);
    text-align: left;
    background: rgba(16, 104, 178, 0.08);
    border-radius: 999px;
  }

  .list td:nth-of-type(1):before {
    content: "Sr. No.";
    font-weight: bold;
  }

  .list td:nth-of-type(2):before {
    content: "Cir. No.";
    font-weight: bold;
  }

  .list td:nth-of-type(3):before {
    content: "Particulars";
    font-weight: bold;
  }

  .list td:nth-of-type(4):before {
    content: "Download Link";
    font-weight: bold;
  }

}

@media only screen and (max-width: 766px),
(min-device-width: 768px) and (max-device-width: 766px) {

  .listone {
    --listone-accent: var(--color-primary);
    --listone-ink: var(--color-dark);
    --listone-line: var(--color-border);
    --listone-soft: var(--color-surface);
    --listone-label-width: 25%;
    --listone-label-gap: 0px;
    display: block;
  }

  .listone table,
  .listone thead,
  .listone tbody,
  .listone th,
  .listone td,
  .listone tr {
    display: block;
  }

  .listone th {
    display: none;
  }

  .listone thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }

  .listone tr {
    margin: 0 0 0.65rem 0;
    border: 1px solid var(--listone-line);
    border-radius: 16px;
    background: transparent;
    box-shadow: 0 10px 20px rgba(16, 104, 178, 0.1);
    overflow: hidden;
  }

  .listone tr:nth-child(odd) {}

  .listone td {
    border: none;
    position: relative;
    padding: 10px 14px 0 calc(var(--listone-label-width) + var(--listone-label-gap));
    min-height: 2.6rem;
    text-align: right;
    background-color: transparent;
    border-bottom: 1px dashed var(--listone-soft);
    color: var(--listone-ink);
    font-weight: 600;
  }

  .listone td:last-child {
    border-bottom: none;
  }

  .listone td:before {
    position: absolute;
    top: 0.6rem;
    left: 12px;
    width: var(--listone-label-width);
    padding: 4px 8px;
    white-space: nowrap;
    line-height: 1.2;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--listone-accent);
    text-align: left;
    background: rgba(16, 104, 178, 0.08);
    border-radius: 999px;
  }

  .listone td:nth-of-type(1):before {
    content: "Sr. No.";
    font-weight: bold;
  }

  .listone td:nth-of-type(2):before {
    content: "Particulars";
    font-weight: bold;
  }

  .listone td:nth-of-type(3):before {
    content: "Download Link";
    font-weight: bold;
  }

  .listone td:nth-of-type(2) {
    padding-top: 10px;
    text-align: right;
  }
}

#footer,
footer {
  background-color: white;
  color: var(--color-dark);
}

footer a,
footer .nav-link,
footer .link-dark {
  color: var(--color-dark) !important;
}

footer a:hover,
footer .nav-link:hover,
footer .link-dark:hover {
  color: var(--color-primary) !important;
}

footer .border-top {
  border-top-color: rgba(77, 77, 77, 0.2) !important;
}

/* Landing page (section/index.php) */
.section-shell {
  background: linear-gradient(140deg, #f8fbff 0%, #ffffff 50%, #f4f8ff 100%);
}

.section-card {
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 16px;
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(16, 104, 178, 0.12);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease;
}

.section-card h5 {
  font-weight: 700;
  color: var(--color-primary);
}

.section-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 50px rgba(16, 104, 178, 0.16);
}

.section-divider {
  height: 1px;
  background: rgba(16, 104, 178, 0.16);
  border: 0;
}

.badge-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.9rem;
  background: rgba(16, 104, 178, 0.12);
  color: var(--color-primary);
}

.social-link {
  color: var(--color-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
}

.social-link:hover {
  color: var(--color-accent);
}

.social-link kbd {
  background: rgba(16, 104, 178, 0.14);
  border-radius: 10px;
  color: var(--color-primary);
}

.section-card .input-group {
  border: 1px solid rgba(16, 104, 178, 0.22);
  border-radius: 14px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 8px 16px rgba(16, 104, 178, 0.06);
  transition:
    box-shadow 0.15s ease,
    border-color 0.15s ease;
}

.section-card .input-group:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 12px 26px rgba(16, 104, 178, 0.16);
}

.section-card .input-group-text {
  background: linear-gradient(135deg, #f2f7ff, #e8f0ff);
  border: 1px solid rgba(16, 104, 178, 0.18);
  border-radius: 12px 0 0 12px;
  min-height: 52px;
  padding: 0 16px;
  color: var(--color-primary);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.section-card .form-control {
  border: 1px solid rgba(16, 104, 178, 0.18);
  border-left: 0;
  border-radius: 0 12px 12px 0;
  min-height: 52px;
  padding: 14px 16px;
  background: transparent;
  box-shadow: none;
}

.section-card .form-control:focus {
  box-shadow: none;
}

.filter-input-group .input-group-text,
.filter-input-group .form-control,
.filter-input-group .form-select {
  min-height: 52px;
}

.filter-input-group .form-control,
.filter-input-group .form-select {
  padding-top: 12px;
  padding-bottom: 12px;
}

.filter-action .btn {
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

/* Staff modal styles */
.staff-modal .modal-content {
  border-radius: 18px;
  border: 1px solid rgba(16, 104, 178, 0.14);
  box-shadow: 0 20px 50px rgba(16, 104, 178, 0.18);
  overflow: hidden;
}
.staff-modal .modal-header {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.12),
    rgba(80, 183, 72, 0.1)
  );
  border-bottom: 1px solid rgba(16, 104, 178, 0.14);
}
.staff-modal .modal-hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(16, 104, 178, 0.12);
  color: var(--color-primary, #1068b2);
  font-weight: 700;
  font-size: 0.95rem;
}
.staff-modal .option-tile {
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 14px;
  background: #f8fbff;
  box-shadow: 0 10px 24px rgba(16, 104, 178, 0.1);
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease;
}
.staff-modal .option-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(16, 104, 178, 0.16);
}
.staff-modal .option-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: #fff;
  display: grid;
  place-items: center;
  border: 1px solid rgba(16, 104, 178, 0.1);
}

.btn-brand {
  background: linear-gradient(
    120deg,
    var(--color-primary),
    var(--color-accent)
  );
  border: 0;
  color: #fff;
  border-radius: 12px;
  padding: 12px;
  font-weight: 700;
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease;
}

.btn-brand:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(16, 104, 178, 0.22);
  color: #fff;
}

/* Global button styling to align with login CTA */
.btn,
.btn-primary,
.btn-success,
.btn-dark {
  background: linear-gradient(
    120deg,
    var(--color-primary),
    var(--color-accent)
  );
  border: 0;
  color: #fff !important;
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(16, 104, 178, 0.16);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    opacity 0.15s ease;
}

.btn:hover,
.btn-primary:hover,
.btn-success:hover,
.btn-dark:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(16, 104, 178, 0.22);
  color: #fff !important;
  opacity: 0.98;
}

#example_paginate .active .page-link {
  background-color: var(--color-primary);
  border: 1px solid var(--color-primary);
}

.accordion {
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.result-table th,
.result-table td {
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}

.result-table th {
  background-color: var(--color-surface-alt);
  color: var(--color-dark);
}

.result-table tr:nth-child(even) {
  background-color: var(--color-surface);
}

#calendar {
  width: 100%;
  margin: 0 auto;
  min-height: 520px;
  padding: 4px;
}

.fc {
  font-family: inherit;
}

.fc-toolbar {
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.fc-toolbar-title {
  font-size: 1.1rem;
  color: var(--color-dark);
}

.fc-toolbar-chunk {
  display: flex;
  align-items: center;
  gap: 8px;
}

.fc-button-primary {
  background: linear-gradient(135deg, #1068b2, #50b748);
  border: none;
  box-shadow: 0 4px 10px rgba(16, 104, 178, 0.2);
  border-radius: 10px;
}

.fc-button-primary:not(:disabled).fc-button-active,
.fc-button-primary:not(:disabled):active,
.fc-button-primary:not(:disabled):hover {
  background: linear-gradient(135deg, #0c5795, #3fa23a);
  border: none;
}

/* 404 page */
.not-found-shell {
  background:
    radial-gradient(
      circle at 18% 12%,
      rgba(16, 104, 178, 0.12),
      transparent 34%
    ),
    radial-gradient(circle at 80% 0%, rgba(80, 183, 72, 0.16), transparent 30%),
    #f7fbff;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: clamp(32px, 6vw, 82px) clamp(12px, 5vw, 28px) clamp(70px, 8vw, 110px);
}

.not-found-card {
  background: #ffffff;
  border: 1px solid rgba(16, 104, 178, 0.14);
  border-radius: 18px;
  box-shadow: 0 18px 42px rgba(16, 104, 178, 0.16);
  padding: clamp(24px, 4vw, 44px);
  display: grid;
  gap: 16px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.not-found-card::after {
  content: "";
  position: absolute;
  inset: 10px -50px auto auto;
  width: 120px;
  height: 120px;
  background: radial-gradient(
    circle,
    rgba(16, 104, 178, 0.12),
    transparent 60%
  );
  transform: rotate(18deg);
  pointer-events: none;
}

.not-found-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-inline: auto;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  color: var(--color-primary);
  background: rgba(16, 104, 178, 0.12);
}

.not-found-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 0 4px rgba(80, 183, 72, 0.14);
  display: inline-block;
}

.not-found-art {
  width: min(240px, 48vw);
  margin: 6px auto 2px;
  display: block;
  filter: drop-shadow(0 10px 30px rgba(16, 104, 178, 0.12));
}

.not-found-code {
  font-size: clamp(44px, 7vw, 84px);
  font-weight: 800;
  margin: 4px 0;
  color: var(--color-primary);
  letter-spacing: 0.02em;
}

.not-found-title {
  font-size: clamp(18px, 2.4vw, 24px);
  font-weight: 700;
  margin: 0;
  color: #0f2942;
}

.not-found-hint {
  color: #6b7c90;
  margin: 6px 0 0;
  font-size: 15px;
}

.not-found-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.not-found-cta {
  border-radius: 12px;
  padding: 12px 18px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  transition:
    transform 0.12s ease,
    box-shadow 0.16s ease,
    opacity 0.16s ease;
}

.not-found-cta.primary {
  background: linear-gradient(
    120deg,
    var(--color-primary),
    var(--color-accent)
  );
  color: #fff;
  border: 0;
  box-shadow: 0 14px 30px rgba(16, 104, 178, 0.24);
}

.not-found-cta.ghost {
  background: #f4f8ff;
  color: var(--color-primary);
  border: 1px solid rgba(16, 104, 178, 0.14);
  box-shadow: none;
}

.not-found-cta:hover {
  transform: translateY(-1px);
  opacity: 0.98;
}

.not-found-cta:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}

.not-found-support {
  font-size: 13px;
  color: #6b7c90;
  margin-top: 4px;
}

.not-found-support a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: none;
}

.not-found-support a:hover {
  color: var(--color-accent);
}

@media (max-width: 576px) {
  .not-found-shell {
    padding-top: 16px;
  }

  .not-found-art {
    width: 180px;
  }
}

.fc-daygrid-event {
  border-radius: 10px;
  padding: 5px 8px;
  border: none;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
}

.fc-daygrid-day-frame {
  background: var(--color-surface);
  border-radius: 10px;
  padding: 6px;
  transition:
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.fc-daygrid-day:hover .fc-daygrid-day-frame {
  background: #f0f6ff;
  box-shadow: 0 4px 10px rgba(16, 104, 178, 0.12);
}

.fc-day-today .fc-daygrid-day-frame {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.12),
    rgba(80, 183, 72, 0.12)
  );
  box-shadow: inset 0 0 0 1px rgba(16, 104, 178, 0.18);
}

.fc-daygrid-day-number {
  color: var(--color-dark);
  font-weight: 600;
}

.fc-col-header-cell-cushion {
  color: var(--color-dark);
  font-weight: 700;
}

.fc-daygrid-event {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.9),
    rgba(80, 183, 72, 0.9)
  );
  color: #fff;
  font-weight: 600;
}

.fc-daygrid-event .fc-event-time,
.fc-daygrid-event .fc-event-title {
  color: #fff;
}

.fc-theme-standard .fc-scrollgrid {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border);
}

/* Ensure calendar modals sit above other elements */
.modal {
  z-index: 9999 !important;
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.modal-backdrop {
  z-index: 9998 !important;
  position: fixed !important;
}

.fc-view-container {
  font-size: 1rem;
}

/* Adjust font sizes for smaller screens */
@media (max-width: 600px) {
  #calendar {
    font-size: 14px;
  }

  .fc-toolbar-title {
    font-size: 1rem;
  }
}

/* Adjust column formats for smaller screens */
@media (max-width: 480px) {
  .fc-scroller {
    overflow-x: auto;
    white-space: nowrap;
  }

  .fc-day-grid {
    display: block;
  }

  .fc-day-header,
  .fc-day-top {
    width: auto !important;
  }
}

/* Adjust event display for smaller screens */
@media (max-width: 768px) {
  .fc-time-grid-event,
  .fc-day-grid-event {
    font-size: 12px;
    padding: 4px;
  }
}

.fc-center h2 {
  font-size: 1.2rem !important;
  font-weight: bold;
}

.fc-head {
  background-color: var(--color-dark);
  color: white;
}

.fc-row {
  padding: 7px 0px 7px 0px;
}

.fc-day-grid-container {
  height: 100% !important;
}

.fc-scroller {
  overflow: hidden !important;
}

.fc-agendaWeek-view {
  height: 100% !important;
}

.fc-agendaDay-view {
  height: 100% !important;
}

.fc-day-number {
  font-size: 2.2vw !important;
}

.fc-time-grid-container {
  height: 100% !important;
}

.fc-event {
  background-color: var(--color-accent) !important;
  border: solid 0 var(--color-border);
}

.fc-title {
  font-size: 0.7rem !important;
}

.table th {
  background-color: var(--color-primary) !important;
  color: white !important;
}

/* Home / section landing */
.home-shell {
  background: linear-gradient(180deg, #f8fbff 0%, #ffffff 40%, #f6f9ff 100%);
}

.home-card {
  background: #ffffff;
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 16px;
  box-shadow: 0 14px 30px rgba(16, 104, 178, 0.12);
  overflow: hidden;
}

.home-card-header {
  background: linear-gradient(135deg, #1068b2, #0d5a98);
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
}

.home-card h6,
.home-card .h6 {
  color: #0d5a98;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  position: relative;
  padding-bottom: 10px;
}

.home-card h6::after,
.home-card .h6::after {
  content: "";
  display: block;
  width: 72px;
  height: 3px;
  background: linear-gradient(135deg, #1068b2, #50b748);
  border-radius: 6px;
  margin-top: 8px;
}

.home-card .section-subhead {
  color: #50b748;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.home-link-list .home-link-item {
  border: 0;
  border-bottom: 1px solid rgba(16, 104, 178, 0.08);
  padding: 12px 16px;
  font-weight: 600;
  color: #0f1624;
  display: flex;
  align-items: center;
  gap: 8px;
}

.home-link-list .home-link-item:last-child {
  border-bottom: 0;
}

.home-link-list .home-link-item:hover {
  background: rgba(16, 104, 178, 0.06);
}

.home-card-img {
  max-height: 140px;
  object-fit: contain;
}

.home-banner img {
  border: 1px solid rgba(16, 104, 178, 0.08);
}

.home-action-btn {
  font-weight: 800;
  letter-spacing: 0.05em;
  padding: 12px 14px;
}

.home-tile {
  background-color: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 14px;
  box-shadow: 0 12px 22px rgba(16, 104, 178, 0.12);
  min-height: 120px;
  transition:
    transform 0.12s ease,
    box-shadow 0.15s ease,
    border-color 0.12s ease;
  color: #0f1624;
}

.home-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 32px rgba(16, 104, 178, 0.18);
  border-color: rgba(16, 104, 178, 0.24);
}

.tile-icon {
  width: 3rem;
  opacity: 0.85;
}

.latest-update-link {
  text-decoration: none;
  display: block;
  border-radius: 12px;
  padding: 6px 8px;
  transition: background 0.12s ease;
}

.latest-update-link:hover {
  background: rgba(16, 104, 178, 0.08);
}

.home-news-item {
  background: #f8fbff;
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 12px;
}

.home-news-title {
  color: #000000;
}

.home-news-title a {
  color: #000000;
  font-weight: 700;
  text-decoration: none;
}

.home-news-title a:hover {
  text-decoration: none;
}

.home-card blockquote {
  position: relative;
  margin: 0;
  padding: 16px 16px 16px 22px;
  border-left: 4px solid #1068b2;
  background: rgba(16, 104, 178, 0.04);
  border-radius: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.home-card blockquote::before {
  content: "“";
  position: absolute;
  top: 6px;
  left: 8px;
  color: #1068b2;
  font-size: 26px;
  line-height: 1;
  opacity: 0.8;
}

.home-card blockquote .lead {
  color: #0f1624;
  font-weight: 700;
}

.link a {
  display: block;
  padding: 10px 12px;
  border-radius: 10px;
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.06),
    rgba(80, 183, 72, 0.06)
  );
  border: 1px solid rgba(16, 104, 178, 0.12);
  color: #0f1624;
  font-weight: 600;
  text-decoration: none;
  transition:
    transform 0.12s ease,
    box-shadow 0.15s ease,
    border-color 0.12s ease;
}

.link a + a {
  margin-top: 10px;
}

.link a:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(16, 104, 178, 0.12);
  border-color: rgba(16, 104, 178, 0.24);
  color: #0d5a98;
}

.footer-main {
  background: var(--color-background);
  border-top: 1px solid rgba(16, 104, 178, 0.12);
  border-bottom: 1px solid rgba(16, 104, 178, 0.08);
  padding-bottom: 24px;
  position: relative;
  z-index: 1;
  padding-top: 14px;
}

.footer-main h6 {
  color: #0d5a98;
  letter-spacing: 0.05em;
}

.footer-main .nav-link,
.footer-main a {
  color: #0f1624;
}

.footer-main .nav-link:hover,
.footer-main a:hover {
  color: #0d5a98 !important;
}

.footer-meta {
  border-top: 1px solid #50b748;
}

/* Footer highlight links */

/* Header and navigation */
.navbar-primary {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.98),
    rgba(12, 82, 148, 0.95)
  );
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 32px rgba(16, 104, 178, 0.28);
  backdrop-filter: blur(6px);
}

.navbar-secondary {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.95),
    rgba(80, 183, 72, 0.92)
  );
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 12px 30px rgba(16, 104, 178, 0.25);
  backdrop-filter: blur(6px);
}

.navbar-login {
  background:
    radial-gradient(circle at 12% 14%, rgba(99, 211, 255, 0.2), transparent 34%),
    linear-gradient(120deg, #062a4d 0%, #0d4c83 52%, #0c3f72 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 16px 34px rgba(5, 22, 45, 0.34);
  backdrop-filter: blur(10px);
}

.navbar-login-inner {
  min-height: 72px;
}

.login-brand {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  text-decoration: none;
  color: #ecf6ff !important;
}

.login-brand-mark {
  font-size: 1.04rem;
  font-weight: 800;
  letter-spacing: 0.09em;
}

.login-brand-dot {
  opacity: 0.6;
  font-size: 0.8rem;
}

.login-brand-sub {
  font-size: 1.04rem;
  letter-spacing: 0.09em;
  font-weight: 400;
}

.navbar-login .navbar-toggler {
  border: 1px solid rgba(255, 255, 255, 0.38);
  border-radius: 10px;
  padding: 6px 10px;
}

.navbar-login .navbar-toggler:focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.18);
}

.login-nav-desktop {
  margin-left: 18px;
}

.login-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 999px;
  padding: 8px 14px !important;
  font-weight: 700;
  letter-spacing: 0.01em;
  background: rgba(255, 255, 255, 0.08);
  color: #f2f8ff !important;
  transition:
    background 0.2s ease,
    transform 0.15s ease,
    border-color 0.2s ease;
}

.login-nav-link:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.58);
  transform: translateY(-1px);
}

.login-mobile-panel {
  border-top: 1px dashed rgba(255, 255, 255, 0.28);
  padding-top: 14px;
}

.login-mobile-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  color: #ffffff !important;
  text-decoration: none;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  margin-bottom: 8px;
}

.login-mobile-link:hover,
.login-mobile-link:focus {
  color: #ffffff !important;
}

.login-mobile-card {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 12px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.08);
  margin-top: 10px;
}

.login-mobile-title {
  color: #ecf6ff;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-bottom: 10px;
}

.header-hero {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.92),
    rgba(80, 183, 72, 0.88)
  );
}

.login-hero {
  position: relative;
  overflow: hidden;
  padding-top: 3.6rem !important;
  padding-bottom: 3.4rem !important;
}

.login-hero-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  align-items: center;
  gap: 24px;
}

.login-hero::before {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  right: -120px;
  top: -140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.23), transparent 70%);
}

.login-hero::after {
  content: "";
  position: absolute;
  width: 280px;
  height: 280px;
  left: -120px;
  bottom: -140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.16), transparent 70%);
}

.login-hero .container {
  position: relative;
  z-index: 1;
}

.login-hero,
.login-hero * {
  color: #ffffff;
}

.login-hero-copy {
  text-align: left;
}

.login-hero-tag {
  display: inline-flex;
  margin-top: 12px;
  margin-bottom: 12px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.12);
}

.bank-name-english {
  font-family: "amino-regular-13", "Roboto", sans-serif;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
  margin: 0;
}

.bank-name-hindi {
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
  margin: 0;
}

.bank-name-english,
.bank-name-hindi {
  display: block;
  width: auto;
  text-align: left;
  line-height: 1.2;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.bank-name-english {
  font-size: clamp(1.18rem, 2.9vw, 2.25rem);
  letter-spacing: 0.03em;
  max-width: 24ch;
  width: 100%;
}

.bank-name-hindi {
  font-size: clamp(1.18rem, 2.9vw, 2.25rem);
  margin-top: 8px;
  max-width: 24ch;
  width: 100%;
}

/* Desktop homepage hero alignment and scale */
.header-hero-copy-desktop .bank-name-english,
.header-hero-copy-desktop .bank-name-hindi,
.header-hero-copy-desktop .login-hero-tag {
  text-align: right;
  margin-left: auto;
}

.header-hero-copy-desktop .bank-name-english {
  font-size: clamp(0.92rem, 1.15vw, 1.06rem);
  max-width: none;
  line-height: 1.2;
  letter-spacing: 0.02em;
}

.header-hero-copy-desktop .bank-name-hindi {
  font-size: clamp(0.92rem, 1.12vw, 1.04rem);
  max-width: none;
  line-height: 1.2;
}

.header-hero-copy-desktop .login-hero-tag {
  font-size: clamp(0.64rem, 0.8vw, 0.7rem);
  padding: 4px 10px;
  letter-spacing: 0.08em;
}

@media (min-width: 1025px) {
  .header-hero#desktop {
    --desktop-logo-height: clamp(68px, 4.9vw, 112px);
    padding-top: 2.75rem !important;
    padding-bottom: 2rem !important;
  }

  .header-hero#desktop .insight-logo {
    height: var(--desktop-logo-height);
    width: auto;
  }

  .header-hero#desktop .row.py-3 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .header-hero#desktop .mb-3 {
    margin-bottom: 0 !important;
  }

  .header-hero-row-desktop {
    --hero-pair-height: var(--desktop-logo-height);
    gap: 16px;
    align-items: stretch;
    flex-wrap: nowrap;
  }

  .header-hero-row-desktop .header-hero-emblem-desktop {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex: 0 0 auto;
    padding: 0 !important;
    height: var(--hero-pair-height);
  }

  .header-hero-row-desktop .header-hero-emblem-desktop .hpgb-logo {
    height: var(--hero-pair-height);
    width: auto;
    max-height: var(--hero-pair-height);
    margin-bottom: 0 !important;
  }

  .header-hero-row-desktop .header-hero-copy-desktop {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
    gap: 5px;
    flex: 0 1 auto;
    padding: 0 !important;
    margin: 0 !important;
    height: var(--hero-pair-height);
  }

  .header-hero-copy-desktop .bank-name-english,
  .header-hero-copy-desktop .bank-name-hindi,
  .header-hero-copy-desktop .login-hero-tag {
    margin-top: 0;
    margin-bottom: 0;
  }

  .header-hero-copy-desktop .bank-name-english {
    font-size: clamp(1.12rem, 1.45vw, 1.36rem);
    white-space: nowrap;
  }

  .header-hero-copy-desktop .bank-name-hindi {
    font-size: clamp(1.52rem, 2.1vw, 1.84rem);
    font-weight: 700;
    line-height: 1.15;
  }

  .header-hero-copy-desktop .login-hero-tag {
    font-size: clamp(0.6rem, 0.74vw, 0.68rem);
    padding: 4px 10px;
  }
}

.login-hero-links {
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.login-hero-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  border-radius: 999px;
  padding: 9px 13px;
  font-size: 0.82rem;
  font-weight: 700;
  color: #ecf6ff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.1);
}

.login-hero-emblem {
  display: flex;
  justify-content: center;
}

.login-hero-logo-wrap {
  width: min(240px, 62vw);
  aspect-ratio: 1 / 1;
  border-radius: 28px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.94), rgba(231, 243, 255, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 24px 42px rgba(6, 32, 65, 0.24);
}

.bank-ownership {
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}

.navbar-primary .nav-link,
.navbar-secondary .nav-link {
  font-weight: 700;
  letter-spacing: 0.01em;
  border-radius: 12px;
  padding: 9px 13px;
  transition:
    background 0.2s ease,
    transform 0.15s ease;
}

.navbar-primary .nav-link:hover,
.navbar-secondary .nav-link:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #e7f3ff !important;
  transform: translateY(-1px);
}

.navbar-primary .navbar-brand {
  font-weight: 800;
  color: #ffffff;
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.navbar-primary .navbar-toggler {
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.navbar-secondary .navbar-brand {
  font-weight: 800;
  color: #ffffff;
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

.navbar-secondary .navbar-toggler {
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.search-modern .input-group-text {
  background: linear-gradient(135deg, #f2f7ff, #e8f0ff);
  border: 1px solid rgba(16, 104, 178, 0.28);
  border-right: 0;
  border-radius: 12px 0 0 12px;
  color: var(--color-primary);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.search-modern .form-control {
  border: 1px solid rgba(16, 104, 178, 0.28);
  border-left: 0;
  border-radius: 0 12px 12px 0;
  padding: 10px 12px;
  min-height: 46px;
}

.search-modern .form-control:focus {
  box-shadow: 0 0 0 0.2rem rgba(16, 104, 178, 0.14);
  border-color: var(--color-primary);
}

.dropdown-menu {
  border: 1px solid rgba(16, 104, 178, 0.12);
  border-radius: 14px;
  padding: 10px;
  box-shadow: 0 18px 40px rgba(16, 104, 178, 0.2);
  background: linear-gradient(160deg, #ffffff 0%, #f8fbff 100%);
  min-width: 220px;
}

.dropdown-menu .dropdown-item {
  border-radius: 12px;
  padding: 12px 14px;
  font-weight: 700;
  color: #0f1624;
  display: flex;
  align-items: center;
  gap: 8px;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    transform 0.12s ease,
    box-shadow 0.15s ease;
}

.dropdown-menu .dropdown-item:hover {
  background: rgba(16, 104, 178, 0.1);
  color: #0d5a98;
  transform: translateX(2px);
  box-shadow: inset 0 0 0 1px rgba(16, 104, 178, 0.18);
}

.latest-card-modern {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.08),
    rgba(80, 183, 72, 0.08)
  );
  border: 1px solid rgba(16, 104, 178, 0.16);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.08);
}

.latest-icon-wrap {
  display: grid;
  place-items: center;
  width: 96px;
  height: 96px;
  border-radius: 20px;
  background: #ffffff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.latest-icon {
  width: 72px;
}

.image-card-modern {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.08),
    rgba(80, 183, 72, 0.08)
  );
  border: 1px solid rgba(16, 104, 178, 0.16);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.08);
}

.image-icon-wrap {
  position: relative;
  width: 100%;
  min-height: 220px;
  border-radius: 16px;
  overflow: hidden;
  background: #f5f7fa;
}

.image-icon-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(16, 104, 178, 0) 0%,
    rgba(16, 104, 178, 0.35) 100%
  );
  pointer-events: none;
}

.image-icon {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.latest-table-card {
  position: relative;
  overflow: hidden;
  border: 1px solid #e7ecf3;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
  box-shadow: 0 18px 40px rgba(16, 104, 178, 0.12);
  z-index: 0;
}

.latest-table-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 6px;
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.9),
    rgba(80, 183, 72, 0.9)
  );
}

.latest-table-card::after {
  content: "";
  position: absolute;
  right: -60px;
  top: -60px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: radial-gradient(
    circle at center,
    rgba(16, 104, 178, 0.12),
    transparent 60%
  );
  z-index: -1;
}

.navbar {
  z-index: 1050;
}

.navbar-primary {
  z-index: 1300;
}

.navbar-secondary {
  z-index: 1050;
}

.proforma-tile {
  background-size: cover;
  background-position: center;
  background-image: url(../assets/makerShade.png);
  background-image: image-set(url(../assets/makerShade.png.webp) type("image/webp"), url(../assets/makerShade.png) type("image/png"));
  border: 1px solid rgba(16, 104, 178, 0.18);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
  border-radius: 18px;
  padding: 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 170px;
  position: relative;
  overflow: hidden;
  transition:
    transform 0.12s ease,
    box-shadow 0.15s ease,
    border-color 0.15s ease,
    filter 0.15s ease,
    translate 0.15s ease;
}

.proforma-tile:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 36px rgba(16, 104, 178, 0.18);
  border-color: rgba(16, 104, 178, 0.3);
  filter: saturate(1.05);
}

.proforma-tile img {
  filter: drop-shadow(0 6px 12px rgba(0, 0, 0, 0.08));
  max-width: 68px;
}

.proforma-icon-wrap {
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  background: rgba(255, 255, 255, 0.18);
  border-radius: 14px;
  backdrop-filter: blur(2px);
  flex-shrink: 0;
}

.proforma-text .label {
  color: #0b4a7e;
  font-weight: 800;
  letter-spacing: 0.05em;
}

.proforma-text .helper {
  color: rgba(11, 74, 126, 0.8);
  font-size: 0.9rem;
  line-height: 1.3;
}

.proforma-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.08),
    rgba(16, 104, 178, 0.04)
  );
  pointer-events: none;
}

.proforma-tile h6 {
  color: #0b4a7e;
  position: relative;
  z-index: 1;
  letter-spacing: 0.02em;
}

@media (max-width: 766px) {
  .proforma-tile {
    min-height: 0;
    padding: 12px;
    gap: 10px;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .proforma-icon-wrap {
    width: 64px;
    height: 64px;
    border-radius: 12px;
  }

  .proforma-tile img {
    max-width: 52px;
  }

  .proforma-text .helper {
    font-size: 0.82rem;
  }
}
.latest {
  --latest-accent: var(--color-primary);
  --latest-ink: var(--color-dark);
  --latest-line: var(--color-border);
  --latest-soft: var(--color-surface);
}

/* Compact table buttons */
.table .btn {
	padding: 5px 10px;
	font-size: 0.78rem;
	line-height: 1.1;
	border-radius: 8px;
}

/* Gallery */
.gallery-card {
	position: relative;
	border-radius: 14px;
	overflow: hidden;
  box-shadow: 0 18px 36px rgba(16, 104, 178, 0.12);
  border: 1px solid rgba(16, 104, 178, 0.1);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease;
  background: #fff;
}

.gallery-card img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.gallery-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 44px rgba(16, 104, 178, 0.18);
}

.gallery-meta {
  padding: 10px 12px;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.95),
    rgba(245, 249, 255, 0.95)
  );
}

.gallery-meta .title {
  font-weight: 800;
  color: #0b4a7e;
}

.gallery-meta .helper {
  color: rgba(11, 74, 126, 0.8);
  font-size: 0.9rem;
}

.address-card-modern {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.08),
    rgba(80, 183, 72, 0.08)
  );
  border: 1px solid rgba(16, 104, 178, 0.18);
  border-radius: 16px;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.08);
  padding: 0;
  text-align: left;
}

.address-card-modern .bank-name-address {
  display: block;
  font-weight: 800;
  font-size: 18px;
  color: #0b2f4d;
  line-height: 1.3;
}

.address-card-modern p {
  margin-bottom: 0;
  color: #1c1c1c;
  line-height: 1.5;
}

.address-card-modern b {
  color: #0b2f4d;
}

.gallery-hero {
  background: linear-gradient(
    135deg,
    rgba(16, 104, 178, 0.12),
    rgba(80, 183, 72, 0.12)
  );
  border: 1px solid rgba(16, 104, 178, 0.16);
  border-radius: 18px;
  padding: 14px 16px;
}

.gallery-hero .hero-icon {
  width: 64px;
  height: 64px;
}

.gallery-title {
  font-weight: 800;
  font-size: 1.25rem;
  color: #0b4a7e;
}

.gallery-sub {
  color: rgba(11, 74, 126, 0.8);
  font-size: 0.95rem;
}

.gallery-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(16, 104, 178, 0.12);
  color: #0d5a98;
  border: 1px solid rgba(16, 104, 178, 0.2);
  border-radius: 12px;
  padding: 8px 12px;
  font-weight: 700;
  white-space: nowrap;
}

.dropdown-menu .dropdown-divider {
  margin: 8px 0;
  border-top: 1px solid rgba(16, 104, 178, 0.12);
}

.dropdown-menu-compact {
  font-size: 13px;
}

.profile-dropdown {
  background: linear-gradient(180deg, #1f2f5c 0%, #1b2b52 100%);
  color: #eef3ff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 40px rgba(12, 33, 74, 0.35);
  min-width: 320px;
  padding: 14px 12px;
  border-radius: 18px;
  z-index: 2100;
}

.profile-dropdown .avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #1068b2, #0d5a98);
  color: #fff;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
}

.profile-dropdown h6 {
  margin: 0;
  font-weight: 800;
  color: #eef3ff;
}

.profile-dropdown .subline {
  margin: 0;
  color: #a7b3d8;
  letter-spacing: 0.08em;
  font-size: 0.82rem;
  text-transform: uppercase;
}

.profile-dropdown .pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: #eef3ff;
  font-weight: 700;
  font-size: 0.85rem;
}

.profile-dropdown .card-link {
  display: block;
  border-radius: 14px;
  padding: 12px;
  background: rgba(0, 0, 0, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: #eef3ff;
  text-decoration: none;
  transition:
    transform 0.12s ease,
    box-shadow 0.15s ease;
}

.profile-dropdown .card-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.28);
  color: #eef3ff;
}

.profile-dropdown .card-link .label {
  font-weight: 800;
  margin: 0;
}

.profile-dropdown .card-link .helper {
  margin: 0;
  color: #9fb0d6;
  font-size: 0.9rem;
}

.profile-dropdown .signout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  border-radius: 12px;
  padding: 12px;
  margin-top: 6px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #eef3ff;
  text-decoration: none;
  font-weight: 800;
  letter-spacing: 0.05em;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0.08),
    rgba(255, 255, 255, 0.04)
  );
  transition:
    background 0.15s ease,
    transform 0.12s ease;
}

.profile-dropdown .signout:hover {
  background: rgba(255, 255, 255, 0.12);
  transform: translateY(-1px);
  color: #eef3ff;
}

/* Make logout buttons look like links where we converted to POST */
.profile-dropdown .signout.btn,
.profile-dropdown .signout.btn:focus,
.profile-dropdown .signout.btn:hover,
.dropdown-menu .dropdown-item.btn,
.dropdown-menu .dropdown-item.btn:focus,
.dropdown-menu .dropdown-item.btn:hover,
.hero-cta.btn.btn-link {
  background: none;
  border: 0;
  box-shadow: none;
  text-decoration: none;
}

.profile-menu .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  font-weight: 700;
  letter-spacing: 0.01em;
  transition:
    background 0.2s ease,
    transform 0.15s ease,
    color 0.15s ease;
}

.profile-menu .nav-link:hover {
  background: rgba(255, 255, 255, 0.16);
  color: #e7f3ff !important;
  transform: translateY(-1px);
}

.profile-menu .dropdown-menu {
  right: 0;
  left: auto;
  z-index: 2000;
}

.nav-pill {
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 999px;
  padding: 8px 14px;
  font-weight: 600;
}

.nav-pill:hover {
  background: rgba(255, 255, 255, 0.12);
}

.badge-glow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  font-weight: 700;
  font-size: 0.9rem;
}

.brand-text {
  font-size: 16px;
}

.brand-text-lg {
  font-size: 17px;
}

.brand-text-hpgb {
  font-weight: 800;
}

.brand-text-insight {
  font-weight: 400;
}

.icon-18 {
  width: 18px;
  display: inline-block;
}

.icon-20 {
  width: 20px;
  display: inline-block;
}

.hero-logo {
  width: min(165px, 72%);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 24px rgba(7, 42, 79, 0.22));
}

.hero-logo-card {
  background: rgba(255, 255, 255, 0.9);
}

.download-img {
  max-width: 98%;
  height: auto;
}

@media (max-width: 767.98px) {
  .login-nav-desktop {
    display: none !important;
  }
  .navbar-login-inner {
    min-height: 62px;
  }
  .login-hero {
    padding-top: 2.1rem !important;
    padding-bottom: 2.1rem !important;
  }
  .login-hero-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .login-hero-emblem {
    order: 1;
  }
  .login-hero-copy {
    order: 2;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .bank-name-english,
  .bank-name-hindi {
    text-align: center;
  }
  .bank-name-english {
    margin-inline: auto;
    font-size: clamp(1.36rem, 3.35vw, 2.65rem);
  }
  .bank-name-hindi {
    font-size: clamp(1.36rem, 3.35vw, 2.65rem);
  }
  .login-hero-logo-wrap {
    width: min(180px, 58vw);
    border-radius: 22px;
  }
  .hero-logo {
    width: min(122px, 68%);
  }
}

/* Add Circular page */
.page-shell {
  background: radial-gradient(
    circle at 20% 20%,
    #e9f2ff,
    #f6f7fb 38%,
    #ffffff 75%
  );
  min-height: calc(100vh - 74px);
  padding-top: 74px;
}

.page-shell .hero-card {
  background: linear-gradient(135deg, #0f4c81, #1c6ea4);
  color: #fff;
  border: none;
  box-shadow: 0 14px 40px rgba(15, 76, 129, 0.25);
}

.page-shell .section-card {
  border: 1px solid #e4e7ee;
  box-shadow: 0 8px 30px rgba(17, 24, 39, 0.08);
  border-radius: 14px;
}

.page-shell .input-group-text {
  background: #f7f9fc;
  border-right: none;
}

.page-shell .form-control,
.page-shell .form-select {
  border-left: none;
  border-radius: 0 10px 10px 0;
}

.page-shell .badge-soft {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.25);
}

.page-shell .upload-tile {
  background: #f8fafc;
  border: 1px dashed #d7dce5;
  border-radius: 12px;
  padding: 14px;
  height: 100%;
}

.page-shell .upload-tile label {
  margin-bottom: 6px;
}

.page-shell ul.guidelines li {
  margin-bottom: 6px;
}
.u-inline-cfd0e04d {background-color:#A20E37;}
.u-inline-beab5831 {font-size: 16px;}
.u-inline-e78af0b6 {height:100px;}
.u-inline-1d8db72a {width: 5%;}
.u-inline-1c30ab94 {width: 10%;}
.u-inline-8588e44d {width:100%;}
.u-inline-08a0ed40 {text-align:right;}
.u-inline-3ab04b33 {text-align:justify;}
.u-inline-d9943435 {max-width: 500px;}
.u-inline-b893921c {height: 55px; z-index: 9999999;}
.u-inline-b3892f13 {width:10%;}
.u-inline-517ce0e9 {width:16%;}
.u-inline-531911c6 {width:20%;}
.u-inline-32d1c0d6 {max-width: 420px; width: 100%;}
.u-inline-40a393e1 {width: 180px; height: 180px;}
.u-inline-508cd136 {max-width: 120px;}
.u-inline-51820f9f {border-radius: 50%;}
.u-inline-4e12908f {width: 26%;}
.u-inline-5abe2c96 {max-width: 180px; margin: 0 auto;}
.u-inline-3dc4627d {object-fit: cover;}
.u-inline-88aa00c4 {height: 110px;}
.u-inline-1e52ae17 {font-size: 2rem;}
.u-inline-f808f073 {width: 14%;}
.u-inline-09213361 {height: 200px;}
.u-inline-0772aee6 {background: linear-gradient(135deg, #1068b2, #50b748);}
.u-inline-a71fa3e3 {height: 174px;}
.u-inline-9f3aef6c {font-size: 25px; font-weight: bold;}
.u-inline-a0efe743 {font-size: 25px;}
.u-inline-5e5efba1 {font-size: 100px; color: #ffffff;}
.u-inline-982ee645 {color:#ffffff;}
.u-inline-1547a446 {height:auto; background-color:white;}
.u-inline-7e3eaa44 {border:1px solid #ddd; background-color:#212529; color:#ffffff; border-radius: 7px;}
.u-inline-af450e60 {border:1px solid #ddd; padding:10px; border-radius: 7px; background-color: #ffc107;}
.u-inline-67d20e1b {border-top:1px solid #ddd; display: flex; justify-content:center;}
.u-inline-6a5e8cb9 {color:white;}
.u-inline-c7ee8088 {width: 15%;}
.u-inline-375019e7 {width:20px;}
.u-inline-b564289e {background: rgba(80, 183, 72, 0.12); color: var(--color-accent);}
.u-inline-fcb9f755 {width: 30%;}
.u-inline-928e0031 {color: var(--color-primary);}
.u-inline-499df8f2 {font-size: 15px;}
.u-inline-f6dc3fb1 {width:13px;}
.u-inline-4af99740 {width: 10;}
.u-inline-f70f7fc2 {max-width: 220px;}
.u-inline-07143ffd {margin-top: 74px;}
.u-inline-283b8e39 {height:200px;}
.u-inline-52403f0d {height:50px;}
.u-inline-1f026128 {font-size: 1rem;}
.u-inline-b84c7dfa {font-size:13px;}
.u-inline-7611fbd2 {width: 20px;}
.u-inline-f316bbd9 {font-size:21px;}
.u-inline-f6234f9f {color: white;}
.u-inline-6be89683 {color:red; text-align:center;}
.u-inline-c7ca18ed {width: 100%; height: 100%; object-fit: cover; border-radius: 12px;}
.u-inline-587c60d4 {height: 100%;}
.u-inline-a9a63184 {font-size: 60px;}
.u-inline-cc77f0fc {background-color: #f4f4f4; padding: 20px; border-radius: 8px; font-family: \"Segoe UI\", Tahoma, Geneva, Verdana, sans-serif; box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);}
.u-inline-ce63a581 {padding: 20px; border-radius: 8px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); text-align: center;}
.u-inline-1a5c8dcf {max-width: 200px;}
.u-inline-26701864 {background-color: #ffffff; padding: 20px; border-radius: 8px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); text-align: justify; border: 1px solid #ddd;}
.u-inline-c7a99e20 {color: #A20E37; text-align: center;}
.u-inline-30aee747 {font-size: 16px; color: #333;}
.u-inline-bc9cee5c {margin-top: 30px;}
.u-inline-bbf92ae6 {padding: 20px; border-radius: 8px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); text-align: center; color: #777;}
.u-inline-267f6d50 {font-size: 14px;}
.u-inline-f13eb15a {height: 40px; z-index: 9999; top:0px;}
.u-inline-280a35b9 {padding-top: 200px;}
.u-inline-6dde9bdb {min-height: 1080px; max-height:100%;}
.u-inline-e7992da2 {font-size: 0.85rem;}
.u-inline-0d0c9e44 {width:16%; text-align:center;}
.u-inline-d9213d8d {width:20%; text-align:center;}
.u-inline-5d1e14e2 {width: 120px; height: 120px;}
.u-inline-4579a73c {font-size: 0.74rem;}
.u-inline-b7256cad {font-size: .74rem;}
.u-inline-8ebad985 {width: 3rem;}
.u-inline-be744b80 {width: 3rem; height: 3rem;}
.u-inline-a76e4d89 {margin-bottom:-3.2%; margin-left: 2%; position: relative; z-index: 999;}
.u-inline-0d61ee50 {height:100%;}
.u-inline-c2267412 {' . $style . ';}
.u-inline-7aeb7371 {padding-bottom: 34px;}
.u-inline-6ec70819 {font-size: 11px;}
.u-inline-8bdd01f4 {font-size: 17px;}
.u-inline-768e1f23 {font-size: 18px;}
.u-inline-71296b1d {padding-right: 0;}
.u-inline-76674537 {font-size: 13px;}
.u-inline-2975eb41 {padding-top: 0%;}
.profile-img-cover{width:100%;height:100%;object-fit:cover;border-radius:12px;}
.footer-link-white{color:#fff;}
.profile-photo-cover{object-fit:cover;}
.result-score-circle{width:180px;height:180px;}
.dashboard-icon-2rem{font-size:2rem;}

.login-page{min-height:100vh;display:flex;flex-direction:column;}
.login-page .footer-login{border-top:2px solid #50b748;width:100%;margin-top:auto;}

.news-marquee{position:relative;overflow:hidden;width:100%;}
.news-marquee,
.news-marquee span,
.news-marquee a {
  color: #ffffff;
}
.news-track{display:inline-flex;align-items:center;gap:24px;white-space:nowrap;animation:news-scroll 28s linear infinite;}
.news-marquee:hover .news-track{animation-play-state:paused;}
@keyframes news-scroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

.page-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #0f2f5c 0%, #0d5a98 50%, #1068b2 100%);
  transition: opacity 0.35s ease, visibility 0.35s ease;
}

html:not(.page-loaded),
html:not(.page-loaded) body {
  overflow: hidden;
}

html:not(.page-loaded) body > *:not(.page-loader) {
  visibility: hidden;
}

.page-loader__shell {
  width: min(92vw, 520px);
  padding: 28px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 40px rgba(7, 24, 44, 0.35);
  backdrop-filter: blur(6px);
  display: grid;
  gap: 16px;
}

.page-loader__bar,
.page-loader__chip,
.page-loader__panel {
  position: relative;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.14);
  border-radius: 999px;
}

.page-loader__bar {
  height: 12px;
}

.page-loader__bar:nth-child(1) {
  width: 80%;
}

.page-loader__bar:nth-child(2) {
  width: 95%;
}

.page-loader__bar:nth-child(3) {
  width: 70%;
}

.page-loader__row {
  display: flex;
  gap: 12px;
}

.page-loader__chip {
  flex: 1;
  height: 36px;
  border-radius: 14px;
}

.page-loader__panel {
  height: 140px;
  border-radius: 16px;
}

.page-loader__bar::after,
.page-loader__chip::after,
.page-loader__panel::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.35) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  animation: loader-shimmer 1.2s ease-in-out infinite;
}

.page-loaded .page-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

@keyframes loader-shimmer {
  100% {
    transform: translateX(100%);
  }
}

.home-icon-lg {
  font-size: 16px;
}

.home-birthday-icon {
  max-width: 120px;
  width: 100%;
  height: auto;
}

.simpletable,
table.simpletable {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
}

@media (min-width: 992px) {
  .simpletable th,
  .simpletable td {
    text-align: left !important;
  }
}

.simpletable_wrapper {
  color: var(--color-dark);
  padding: 0;
  border-radius: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  overflow-x: auto;
  backdrop-filter: none;
}

.simpletable_wrapper .simpletable_top {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 12px;
  padding: 14px 14px 8px;
  background: transparent;
  border: none;
  box-shadow: none;
}

.simpletable_wrapper .simpletable_length,
.simpletable_wrapper .simpletable_filter {
  width: auto;
  flex: 1 1 0;
}

.simpletable_wrapper .simpletable_length label,
.simpletable_wrapper .simpletable_filter label {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 0.72rem;
  color: var(--color-muted);
  margin-bottom: 12px;
}

.simpletable_wrapper .simpletable_length select,
.simpletable_wrapper .simpletable_filter input {
  width: auto;
  flex: 1 1 auto;
  border: 1px solid rgba(148, 163, 184, 0.6);
  border-radius: 6px;
  padding: 4px 6px;
  min-height: 24px;
  background: transparent;
  box-shadow: none;
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.simpletable_wrapper .simpletable_length select {
  flex: 0 0 auto;
  width: max-content;
  min-width: 0;
  padding: 0 2px;
  text-align: center;
  text-align-last: center;
}

.simpletable_wrapper .simpletable_length select:focus,
.simpletable_wrapper .simpletable_filter input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.25rem rgba(16, 104, 178, 0.18);
  transform: translateY(-1px);
}

.simpletable_info {
  margin: 8px 0 4px;
  color: var(--color-muted);
  font-weight: 600;
  width: 100%;
  display: flex;
  justify-content: center;
  text-align: center;
  padding-bottom: 6px;
}

.simpletable_paginate {
  margin: 0 0 12px;
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  padding: 0 8px 8px;
}

.simpletable_paginate .paginate_button.page-item {
  flex: 0 0 auto;
  display: inline-flex;
  white-space: nowrap;
  flex-shrink: 0;
  border-radius: 6px;
  border: 1px solid rgba(148, 163, 184, 0.6);
  background: transparent;
  color: var(--color-dark);
  box-shadow: none;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  min-width: 30px;
  height: 30px;
}

.simpletable_paginate .paginate_button.page-item .page-link {
  background: transparent;
  color: inherit;
  border: none;
  padding: 0 8px;
  line-height: 30px;
  font-weight: 600;
  font-size: 0.8rem;
}

.simpletable_paginate .paginate_button.page-item:hover {
  background: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
  transform: translateY(-1px);
}

.simpletable_paginate .paginate_button.page-item.active {
  background: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
}

.simpletable_paginate .paginate_button.page-item.disabled {
  opacity: 0.6;
  cursor: default;
}

@media (prefers-color-scheme: dark) {
  .simpletable_wrapper {
    color: #ffffff;
    background: transparent;
    border-color: transparent;
    box-shadow: none;
  }

  .simpletable_wrapper .simpletable_length select,
  .simpletable_wrapper .simpletable_filter input {
    background: transparent;
    color: #e2e8f0;
    border-color: rgba(148, 163, 184, 0.4);
  }

  .simpletable_paginate .paginate_button.page-item {
    background: transparent;
    color: #e2e8f0;
    border-color: rgba(148, 163, 184, 0.4);
  }

  .simpletable_paginate .paginate_button.page-item:hover,
  .simpletable_paginate .paginate_button.page-item.active {
    background: var(--color-primary);
    color: #ffffff;
    border-color: var(--color-primary);
  }
}

.modal-hero{background:linear-gradient(135deg,rgba(16,104,178,0.12),rgba(80,183,72,0.1));border-bottom:1px solid rgba(16,104,178,0.15);}
.modal-content{border:1px solid rgba(16,104,178,0.18);border-radius:18px;box-shadow:0 20px 50px rgba(16,104,178,0.2);overflow:hidden;}
.modal-app-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(16,104,178,0.12);color:var(--color-primary,#1068b2);font-weight:700;font-size:0.95rem;}
.modal-art{width:84px;height:84px;border-radius:20px;background:#f4f8ff;display:grid;place-items:center;border:1px solid rgba(16,104,178,0.1);box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);}
.modal-art svg{width:44px;height:44px;color:var(--color-primary,#1068b2);}
.modal-body ul,.modal-body ol{padding-left:1.25rem;}
.modal-body li{margin-bottom:6px;color:#4d4d4d;}
.modal-footer{background:#f9fbff;border-top:1px solid rgba(16,104,178,0.12);}

.theme-adaptive{background-color:#ffffff;color:#1a1a1a;}
@media (prefers-color-scheme: dark){
	.theme-adaptive{background-color:#1e1e1e;color:#f1f1f1;}
	.theme-adaptive .modal-header,
	.theme-adaptive .modal-body{background-color:#1e1e1e;color:#f1f1f1;}
	.theme-adaptive .table{color:#f1f1f1;}
	.theme-adaptive .table-light th{background-color:#2a2a2a !important;color:#f1f1f1;}
	.theme-adaptive .btn-close{filter:invert(1);}
}

.table-fit{width:100%;font-size:clamp(10px,1.2vw,14px);table-layout:fixed;}
.table-fit th,.table-fit td{padding:4px;word-wrap:break-word;text-align:center;}
@media (max-width: 768px){
	.table-fit th,.table-fit td{font-size:10px;padding:2px;}
}

.unsupported-page{background-color:#A20E37;}
.unsupported-page .nav{list-style-type:none;text-align:center;margin-top:30px;padding:0 20px 20px 0;border-top:1px solid #ddd;}
.unsupported-page .nav li{display:inline-block;padding:10px;border:1px solid #ddd;margin:10px;border-radius:7px;background-color:#f8f9fa;}
.unsupported-page .nav li:hover{background-color:#ffc107;}
.unsupported-page img{border:1px solid #ddd;border-radius:4px;padding:5px;width:300px;height:200px;}
.unsupported-page img:hover{box-shadow:0 0 2px 1px rgba(0,140,186,0.5);}
.unsupported-page figcaption{font-size:20px;font-weight:bold;padding-top:10px;}

.profile-card{border:1px solid #e7ecf3;border-radius:1rem;}
.profile-chip{background:#f8fafc;border:1px solid #e7ecf3;border-radius:0.85rem;padding:12px 14px;height:100%;}
.profile-chip .label{font-size:0.85rem;text-transform:uppercase;letter-spacing:0.03em;color:#6c757d;margin-bottom:4px;}
.profile-chip .value{font-weight:600;color:#1f2a44;margin:0;}
.profile-icon{background:linear-gradient(135deg,#1068b2,#50b748);color:#fff;border-radius:50%;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;}
.statement-card{border:1px solid #e7ecf3;border-radius:1rem;}
.statement-icon{background:linear-gradient(135deg,#1068b2,#50b748);color:#fff;border-radius:14px;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;}
.pf.table{border:none;border-radius:0.85rem;overflow:hidden;}
.pf.table thead th{background:linear-gradient(135deg,#1068b2,#50b748);color:#fff;border:none !important;}
.pf.table tbody td{border-color:#eef1f6;}
.pf.table tbody tr:hover{background:#f6fbff;}
.dataTables_wrapper .dataTables_paginate .paginate_button{border-radius:8px !important;}

.login-icon-15{font-size:15px;}
.btn-icon-34{width:34px;}

.simpletable_paginate .paginate_button.page-item,
.simpletable_paginate .paginate_button.page-item .page-link,
.dataTables_wrapper .dataTables_paginate .paginate_button {
  color: #1f2937 !important;
}

.simpletable_paginate .paginate_button.page-item .page-link,
.dataTables_wrapper .dataTables_paginate .paginate_button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

.simpletable_paginate .paginate_button.page-item.active,
.simpletable_paginate .paginate_button.page-item.active .page-link,
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
  color: #ffffff !important;
}



.simple-editor{width:100%;}
.simple-editor-toolbar{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:0.5rem;}
.simple-editor-toolbar .btn{padding:0.2rem 0.55rem;line-height:1.2;}
.simple-editor-toolbar{padding:6px;border:1px solid #d7dce5;border-radius:10px;background:#f8fafc;}
.simple-editor textarea.form-control{min-height:160px;}
