:root {
  color-scheme: light;
  --ink: #152029;
  --muted: #62717d;
  --line: #d8e0e5;
  --panel: #ffffff;
  --bg: #f5f7f4;
  --green: #23664f;
  --green-dark: #164937;
  --gold: #d99727;
  --red: #b54747;
  --blue: #245c8f;
  --shadow: 0 14px 38px rgba(34, 47, 54, 0.1);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  background: var(--bg);
  color: var(--ink);
  font-family: "Noto Sans Devanagari", "Mangal", "Segoe UI", sans-serif;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

.public-home {
  background: #f7faf7;
  min-height: 100vh;
}

.public-nav {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 74px;
  padding: 12px clamp(16px, 4vw, 56px);
  border-bottom: 3px solid rgba(217, 151, 39, 0.86);
  background:
    linear-gradient(90deg, rgba(6, 38, 26, 0.94), rgba(17, 77, 67, 0.86)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center 42% / cover;
  box-shadow: 0 10px 28px rgba(5, 28, 20, 0.16);
  backdrop-filter: blur(12px);
}

.public-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  color: #ffffff;
  font-weight: 900;
  text-decoration: none;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.24);
}

.public-logo {
  display: grid;
  flex: 0 0 48px;
  place-items: center;
  width: 48px;
  height: 48px;
  overflow: hidden;
  border: 2px solid rgba(255, 224, 163, 0.88);
  border-radius: 50%;
  background: #ffffff;
  color: var(--green);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.18);
}

.public-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.public-logo span {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: var(--green);
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
}

.public-nav nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.public-nav a,
.public-nav button {
  min-height: 38px;
  padding: 0 12px;
  border-radius: 6px;
  background: transparent;
  color: #ffffff;
  font-weight: 800;
  text-decoration: none;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.25);
}

.public-nav button {
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.28);
}

.public-nav button:last-child {
  background: var(--gold);
  color: #16231d;
  border-color: rgba(255, 224, 163, 0.7);
  text-shadow: none;
}

.install-app-button[hidden] {
  display: none !important;
}

.public-nav .install-app-button {
  background: rgba(217, 151, 39, 0.22);
  border-color: rgba(255, 224, 163, 0.68);
  color: #ffffff;
}

.public-scrolling-banner {
  min-height: 42px;
  overflow: hidden;
  border-top: 1px solid rgba(217, 151, 39, 0.55);
  border-bottom: 1px solid rgba(217, 151, 39, 0.55);
  background: var(--green-dark);
  color: #ffffff;
}

.public-scrolling-track {
  display: flex;
  align-items: center;
  width: max-content;
  min-height: 42px;
  gap: 28px;
  padding: 0 0 0 clamp(16px, 4vw, 56px);
  animation: public-banner-scroll 30s linear infinite;
}

.public-scrolling-track span {
  position: relative;
  white-space: nowrap;
  font-weight: 900;
}

.public-scrolling-track span::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-right: 10px;
  border-radius: 50%;
  background: var(--gold);
}

@keyframes public-banner-scroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.public-main {
  width: 100%;
  margin: 0;
}

.public-hero {
  min-height: 520px;
  display: grid;
  align-items: end;
  padding: 96px clamp(18px, 5vw, 72px) 72px;
  color: #ffffff;
  background:
    linear-gradient(90deg, rgba(8, 43, 30, 0.9), rgba(13, 70, 62, 0.55)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center/cover;
}

.public-hero-content {
  width: min(900px, 100%);
}

.public-hero h1 {
  margin-bottom: 14px;
  color: #ffffff;
}

.public-hero-copy {
  max-width: 620px;
  margin-bottom: 14px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 19px;
  font-weight: 800;
}

.public-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 18px 0 0;
}

.public-meta-row span {
  min-height: 34px;
  padding: 7px 11px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-weight: 800;
}

.public-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.public-hero-actions button,
.public-member-login button {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 6px;
  background: var(--gold);
  color: #1c241f;
  font-weight: 900;
}

.public-hero-actions .ghost-btn {
  width: auto;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.34);
}

.public-section {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 54px 0;
}

.public-section.public-band {
  width: 100%;
  padding: 54px max(16px, calc((100% - 1120px) / 2));
  background: #edf4ef;
}

.public-section h2 {
  margin-bottom: 12px;
  color: var(--ink);
  font-size: clamp(24px, 3vw, 34px);
}

.public-section p {
  max-width: 760px;
  color: var(--muted);
  line-height: 1.65;
}

.public-about-section {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  align-items: center;
  gap: 24px;
}

.public-about-copy {
  min-width: 0;
}

.public-about-photo {
  min-height: 260px;
  overflow: hidden;
  border: 1px solid rgba(35, 102, 79, 0.18);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: var(--shadow);
}

.public-about-photo img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
}

.public-info-list,
.public-card-grid,
.public-committee-grid,
.public-check-list,
.public-news-list,
.public-ad-list,
.public-notice-list {
  display: grid;
  gap: 12px;
}

.public-info-list {
  grid-column: 1 / -1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 18px;
}

.public-card-grid,
.public-committee-grid,
.public-news-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 18px;
}

.public-info-list article,
.public-card-grid article,
.public-committee-grid article,
.public-news-card,
.public-ad-card,
.public-notice-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: var(--shadow);
  padding: 18px;
}

.public-news-list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.public-ad-section {
  padding-top: 32px;
}

.public-ad-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 18px;
}

.public-ad-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: stretch;
  padding: 12px;
  color: inherit;
  text-decoration: none;
}

.public-ad-card:first-child {
  grid-column: 1 / -1;
  grid-template-columns: minmax(240px, 0.95fr) minmax(0, 1.05fr);
}

.public-ad-media {
  overflow: hidden;
  border-radius: 8px;
  background: #eef3f1;
  aspect-ratio: 16 / 9;
}

.public-ad-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.public-ad-body {
  display: grid;
  align-content: center;
  min-width: 0;
  padding: 8px;
}

.public-ad-body span {
  color: var(--gold);
  font-size: 13px;
  font-weight: 900;
}

.public-ad-body strong {
  display: block;
  margin-top: 6px;
  color: var(--ink);
  font-size: 22px;
}

.public-ad-body p {
  margin: 8px 0 0;
}

.public-ad-body small {
  width: fit-content;
  margin-top: 14px;
  padding: 7px 12px;
  border-radius: 6px;
  background: rgba(35, 102, 79, 0.1);
  color: var(--green);
  font-weight: 900;
}

.public-news-card {
  display: grid;
  gap: 12px;
  padding: 12px;
}

.public-news-media {
  overflow: hidden;
  border-radius: 8px;
  background: #eef3f1;
  aspect-ratio: 16 / 10;
}

.public-news-media img,
.public-news-media video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.public-news-body {
  min-width: 0;
}

.public-news-body span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.public-news-body strong {
  display: block;
  margin-top: 6px;
  color: var(--ink);
  font-size: 17px;
}

.public-news-body p {
  margin: 8px 0 2px;
}

.public-committee-grid article {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 210px;
  text-align: center;
}

.public-card-grid .nav-icon {
  width: 30px;
  height: 30px;
  margin-bottom: 12px;
  color: var(--green);
}

.public-committee-photo {
  display: grid;
  place-items: center;
  width: 88px;
  height: 96px;
  margin: 0 auto 12px;
  overflow: hidden;
  padding: 4px;
  border: 2px solid var(--green);
  border-radius: 10px;
  outline: 1px solid rgba(217, 151, 39, 0.72);
  background: #ffffff;
  color: var(--green);
  font-size: 34px;
  font-weight: 900;
}

.public-committee-photo img {
  width: 100%;
  height: 100%;
  border-radius: 6px;
  object-fit: cover;
}

.public-committee-photo span {
  width: auto;
  margin: 0;
}

.public-info-list strong,
.public-card-grid strong,
.public-committee-grid strong,
.public-member-login strong,
.public-notice-card strong {
  display: block;
  color: var(--ink);
  font-size: 17px;
}

.public-info-list span,
.public-committee-grid span,
.public-notice-card span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-weight: 700;
}

.public-committee-grid .public-committee-photo span {
  width: auto;
  margin: 0;
  color: var(--green);
  font-weight: 900;
}

.public-check-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 16px;
}

.public-check-list span {
  position: relative;
  min-height: 42px;
  padding: 11px 14px 11px 38px;
  border: 1px solid rgba(35, 102, 79, 0.16);
  border-radius: 8px;
  background: #ffffff;
  font-weight: 800;
}

.public-check-list span::before {
  content: "\2713";
  position: absolute;
  left: 14px;
  color: var(--green);
  font-weight: 900;
}

.public-member-login {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
  padding: 14px;
  border: 1px dashed rgba(35, 102, 79, 0.32);
  border-radius: 8px;
  background: #ffffff;
}

.public-notice-list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 16px;
}

.public-notice-card p {
  margin: 8px 0 0;
}

.public-footer {
  background: #103627;
  color: rgba(255, 255, 255, 0.82);
}

.public-footer-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(0, 1fr));
  gap: 28px;
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 42px 0 30px;
}

.public-footer-brand {
  min-width: 0;
}

.public-footer-logo {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  margin-bottom: 14px;
  overflow: hidden;
  border: 2px solid rgba(217, 151, 39, 0.72);
  border-radius: 50%;
  background: #ffffff;
  color: var(--green);
  font-weight: 900;
}

.public-footer-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.public-footer strong,
.public-footer h3 {
  color: #ffffff;
}

.public-footer-brand > strong {
  display: block;
  font-size: 21px;
}

.public-footer p {
  max-width: 460px;
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.65;
}

.public-footer h3 {
  margin: 0 0 14px;
  font-size: 16px;
}

.public-footer-links,
.public-footer-list {
  display: grid;
  gap: 9px;
}

.public-footer-links a,
.public-footer-list span {
  color: rgba(255, 255, 255, 0.78);
  font-weight: 800;
  text-decoration: none;
}

.public-footer-links a:hover {
  color: #ffffff;
}

.public-footer-list strong {
  font-weight: 900;
}

.public-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 18px 0 22px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.public-footer-bottom span {
  font-weight: 800;
}

.public-footer-bottom button {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 6px;
  background: var(--gold);
  color: #17211c;
  font-weight: 900;
}

.public-suggestion-card {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr minmax(260px, 1.4fr) auto;
  align-items: end;
  gap: 10px;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
}

.public-suggestion-card h3 {
  grid-column: 1 / -1;
  margin-bottom: 4px;
}

.public-suggestion-card input,
.public-suggestion-card textarea {
  min-height: 44px;
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.94);
}

.public-suggestion-card textarea {
  min-height: 44px;
  resize: vertical;
}

.public-suggestion-actions {
  display: flex;
  gap: 8px;
}

.public-suggestion-actions button {
  min-height: 44px;
  padding: 0 14px;
  border-radius: 6px;
  background: var(--gold);
  color: #17211c;
  font-weight: 900;
  white-space: nowrap;
}

.public-suggestion-actions .ghost-btn {
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.26);
}

.public-suggestion-actions button:disabled {
  cursor: not-allowed;
  opacity: 0.48;
}

#publicSuggestionStatus {
  grid-column: 1 / -1;
  min-height: 18px;
  color: #ffe3a7;
  font-weight: 900;
}

.suggestion-admin-panel {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.suggestion-admin-panel .panel-heading {
  margin-bottom: 10px;
}

.login-back-btn {
  min-height: 38px;
  margin-bottom: 14px;
  padding: 0 12px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
  font-weight: 800;
}

.topbar,
.login-screen {
  width: 100%;
}

.login-screen {
  min-height: 100vh;
  padding: 24px;
  display: grid;
  place-items: center;
  color: white;
  background:
    linear-gradient(90deg, rgba(10, 38, 31, 0.9), rgba(17, 58, 70, 0.64)),
    url("https://images.unsplash.com/photo-1561414927-6d86591d0c4f?auto=format&fit=crop&w=1800&q=80") center/cover;
}

.login-card {
  width: min(440px, 100%);
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 8px;
  background: rgba(12, 37, 32, 0.78);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}

.login-card h1 {
  margin-bottom: 22px;
  font-size: clamp(34px, 7vw, 52px);
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-form label,
.login-form p {
  color: rgba(255, 255, 255, 0.82);
}

.login-form button {
  min-height: 46px;
  border-radius: 6px;
  background: var(--gold);
  color: #1c241f;
  font-weight: 900;
}

.login-error {
  min-height: 20px;
  margin: 0;
  color: #ffd0d0;
  font-weight: 800;
}

.login-form .hidden {
  display: none;
}

.topbar {
  min-height: 220px;
  padding: 32px clamp(18px, 4vw, 56px);
  color: white;
  background:
    linear-gradient(90deg, rgba(10, 38, 31, 0.88), rgba(17, 58, 70, 0.68)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center/cover;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.topbar-brand {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  min-width: 0;
}

.topbar-logo {
  flex: 0 0 76px;
  width: 76px;
  height: 76px;
  padding: 5px;
  border: 2px solid rgba(255, 224, 163, 0.88);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
}

.topbar-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 50%;
  display: block;
}

.eyebrow {
  margin: 0 0 10px;
  color: #ffe0a3;
  font-weight: 700;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  max-width: 760px;
  margin-bottom: 0;
  font-size: clamp(32px, 5vw, 58px);
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

h2 {
  margin-bottom: 0;
  font-size: 20px;
}

h3 {
  margin: 24px 0 12px;
  font-size: 17px;
}

.role-switch {
  display: inline-flex;
  gap: 6px;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.36);
  background: rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  backdrop-filter: blur(8px);
}

.role-switch button {
  min-height: 42px;
  padding: 0 16px;
  color: white;
  background: transparent;
  border-radius: 6px;
  white-space: nowrap;
}

.role-switch button.active {
  color: var(--green-dark);
  background: white;
}

.top-actions {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.logout-btn,
.print-inline {
  min-height: 54px;
  padding: 0 16px;
  color: white;
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.36);
  border-radius: 8px;
  font-weight: 800;
}

.print-inline {
  width: 100%;
  margin-top: 18px;
  color: var(--green);
  background: #e7f0eb;
  border-color: var(--line);
}

.session-label {
  margin-top: 12px;
  color: #ffe0a3;
  font-weight: 800;
}

main {
  width: min(1180px, calc(100% - 28px));
  margin: -52px auto 44px;
}

.summary-strip {
  display: grid;
  grid-template-columns: repeat(7, minmax(76px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.summary-strip article,
.quick-actions-strip > div,
.quick-actions-strip > button,
.panel {
  min-width: 0;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}

.summary-strip article,
.quick-actions-strip > div,
.quick-actions-strip > button {
  min-height: 86px;
  padding: 16px;
}

.quick-actions-strip > button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  flex-direction: column;
  min-height: 74px;
  padding: 10px 8px;
  color: var(--ink);
  text-align: center;
}

.quick-actions-strip > button:hover {
  border-color: rgba(35, 102, 79, 0.36);
  background: #f8fbf9;
}

.quick-actions-strip .nav-icon {
  width: 30px;
  height: 30px;
  color: var(--green);
}

.quick-actions-strip strong {
  margin: 0;
  font-size: 13px;
  line-height: 1.15;
}

.summary-strip span,
.detail-grid span {
  display: block;
  color: var(--muted);
  font-size: 14px;
}

.summary-strip strong,
.detail-grid strong {
  display: block;
  margin-top: 8px;
  font-size: 22px;
}

.detail-grid strong {
  font-size: 24px;
}

.view-grid {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 18px;
}

.manager-layout {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.sidebar-toggle {
  display: none;
}

.manager-mode .sidebar-toggle {
  display: inline-flex;
}

.manager-layout.sidebar-collapsed {
  grid-template-columns: minmax(0, 1fr);
}

.manager-layout.sidebar-collapsed .admin-nav {
  display: none;
}

.manager-layout.sidebar-collapsed .admin-page,
.manager-layout.sidebar-collapsed .wide {
  grid-column: 1;
}

.admin-nav {
  position: sticky;
  top: 16px;
  grid-column: 1;
  grid-row: 1 / span 20;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: white;
  box-shadow: var(--shadow);
}

.admin-nav button {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  min-height: 48px;
  padding: 0 12px;
  color: var(--ink);
  background: #eef3f1;
  border-radius: 6px;
  font-weight: 800;
  text-align: left;
}

.admin-nav button.active {
  color: white;
  background: var(--green);
}

.dashboard-tab {
  padding-inline: 12px;
}

.nav-icon {
  position: relative;
  width: 18px;
  height: 18px;
  display: inline-block;
  color: inherit;
  flex: 0 0 auto;
}

.icon-dashboard {
  border-radius: 4px;
  background:
    linear-gradient(currentColor 0 0) left top / 7px 7px no-repeat,
    linear-gradient(currentColor 0 0) right top / 7px 7px no-repeat,
    linear-gradient(currentColor 0 0) left bottom / 7px 7px no-repeat,
    linear-gradient(currentColor 0 0) right bottom / 7px 7px no-repeat;
}

.icon-settings {
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-settings::before {
  content: "";
  position: absolute;
  inset: 5px;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-settings::after {
  content: "";
  position: absolute;
  left: 7px;
  top: -3px;
  width: 2px;
  height: 22px;
  background: currentColor;
  box-shadow: 0 0 0 0 currentColor;
  transform: rotate(45deg);
}

.icon-profile {
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-profile::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 4px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  transform: translateX(-50%);
}

.icon-profile::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 3px;
  width: 11px;
  height: 6px;
  border-radius: 9px 9px 3px 3px;
  background: currentColor;
  transform: translateX(-50%);
}

.icon-members::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 8px;
  height: 8px;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-members::after {
  content: "";
  position: absolute;
  left: 2px;
  bottom: 1px;
  width: 14px;
  height: 8px;
  border: 2px solid currentColor;
  border-radius: 10px 10px 3px 3px;
}

.icon-application {
  border: 2px solid currentColor;
  border-radius: 4px;
}

.icon-application::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 4px;
  width: 7px;
  height: 7px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
}

.icon-application::after {
  content: "";
  position: absolute;
  left: 5px;
  right: 4px;
  bottom: 4px;
  height: 2px;
  background: currentColor;
  box-shadow: 0 -5px 0 currentColor;
}

.icon-savings {
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-savings::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 3px;
  width: 4px;
  height: 8px;
  border-left: 2px solid currentColor;
  border-right: 2px solid currentColor;
}

.icon-shares {
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
}

.icon-shares::before,
.icon-shares::after {
  content: "";
  position: absolute;
  bottom: 3px;
  width: 4px;
  background: currentColor;
  border-radius: 2px 2px 0 0;
}

.icon-shares::before {
  left: 5px;
  height: 8px;
}

.icon-shares::after {
  right: 2px;
  height: 13px;
}

.icon-certificate {
  border: 2px solid currentColor;
  border-radius: 3px;
}

.icon-certificate::before {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  top: 5px;
  height: 2px;
  background: currentColor;
  box-shadow: 0 5px 0 currentColor;
}

.icon-certificate::after {
  content: "";
  position: absolute;
  right: -3px;
  bottom: -3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.icon-loans,
.icon-dues,
.icon-receipt {
  border: 2px solid currentColor;
  border-radius: 4px;
}

.icon-loans::before,
.icon-dues::before,
.icon-receipt::before {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  top: 5px;
  height: 2px;
  background: currentColor;
  box-shadow: 0 5px 0 currentColor;
}

.icon-dues::after {
  content: "";
  position: absolute;
  right: -3px;
  bottom: -2px;
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
}

.icon-emi {
  border: 2px solid currentColor;
  border-radius: 4px;
  background:
    linear-gradient(currentColor 0 0) left 4px top 4px / 3px 3px no-repeat,
    linear-gradient(currentColor 0 0) center top 4px / 3px 3px no-repeat,
    linear-gradient(currentColor 0 0) right 4px top 4px / 3px 3px no-repeat,
    linear-gradient(currentColor 0 0) left 4px bottom 4px / 3px 3px no-repeat,
    linear-gradient(currentColor 0 0) center bottom 4px / 3px 3px no-repeat,
    linear-gradient(currentColor 0 0) right 4px bottom 4px / 3px 3px no-repeat;
}

.icon-reports {
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
}

.icon-reports::before {
  content: "";
  position: absolute;
  left: 4px;
  bottom: 4px;
  width: 10px;
  height: 7px;
  border-left: 2px solid currentColor;
  border-top: 2px solid currentColor;
  transform: skewY(-28deg);
}

.icon-notice {
  border: 2px solid currentColor;
  border-radius: 4px;
}

.icon-notice::before,
.icon-notice::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  height: 2px;
  background: currentColor;
}

.icon-notice::before {
  top: 5px;
  box-shadow: 0 5px 0 currentColor;
}

.icon-notice::after {
  bottom: 4px;
  width: 6px;
}

.icon-news {
  border: 2px solid currentColor;
  border-radius: 3px;
}

.icon-news::before {
  content: "";
  position: absolute;
  left: 3px;
  top: 4px;
  width: 5px;
  height: 5px;
  background: currentColor;
  border-radius: 2px;
}

.icon-news::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 3px;
  top: 4px;
  height: 2px;
  background: currentColor;
  box-shadow: -7px 7px 0 currentColor, 0 7px 0 currentColor;
}

.icon-ad {
  border: 2px solid currentColor;
  border-radius: 50%;
}

.icon-ad::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 7px;
  width: 10px;
  height: 5px;
  border: 2px solid currentColor;
  border-left-width: 4px;
  border-radius: 2px;
  transform: skewX(-10deg);
}

.icon-ad::after {
  content: "";
  position: absolute;
  right: 1px;
  top: 2px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
}

.icon-balance {
  border-top: 2px solid currentColor;
}

.icon-balance::before,
.icon-balance::after {
  content: "";
  position: absolute;
  top: 3px;
  width: 7px;
  height: 11px;
  border: 2px solid currentColor;
  border-top: 0;
  border-radius: 0 0 5px 5px;
}

.icon-balance::before {
  left: 0;
}

.icon-balance::after {
  right: 0;
}

.admin-page:not(.active) {
  display: none;
}

.view-grid > *,
.manager-layout > * {
  min-width: 0;
}

.panel {
  padding: 20px;
}

.wide {
  grid-column: 1 / -1;
}

.manager-layout .admin-page {
  grid-column: 2;
}

.manager-layout .wide {
  grid-column: 2;
}

.hidden {
  display: none;
}

.panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.panel-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.panel-actions .ghost-btn {
  min-width: 92px;
  width: auto;
}

.sub-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 18px 0 12px;
}

.sub-heading h3 {
  margin: 0;
}

.month-filter {
  width: min(220px, 100%);
}

.print-title {
  display: none;
}

.panel-heading span {
  color: var(--muted);
}

.inline-actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.backup-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.backup-actions .ghost-btn {
  width: auto;
  min-width: 92px;
}

.online-sync-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}

.online-sync-actions input[type="password"] {
  width: min(220px, 100%);
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.92);
}

.online-sync-actions .ghost-btn {
  width: auto;
  min-width: 100px;
}

.online-sync-actions label {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: white;
  color: var(--green-dark);
  font-weight: 800;
}

.backup-box {
  display: grid;
  gap: 6px;
  justify-items: end;
}

.backup-status {
  max-width: 620px;
  margin: 0;
  font-size: 12px;
  line-height: 1.35;
  text-align: right;
}

.backup-status.ok {
  color: var(--green);
}

.backup-status.warning {
  color: #a15c00;
  font-weight: 700;
}

.ghost-btn:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.hidden-file {
  display: none;
}

.member-list {
  display: grid;
  gap: 8px;
}

.selected-member-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 86px;
  margin-bottom: 16px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.selected-member-preview img {
  width: 62px;
  height: 62px;
  border-radius: 8px;
  object-fit: cover;
  background: #d9e4df;
  flex: 0 0 auto;
}

.selected-member-preview strong,
.selected-member-preview span {
  display: block;
}

.selected-member-preview span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.member-card {
  width: 100%;
  padding: 12px;
  text-align: left;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.member-card.active {
  border-color: var(--green);
  background: #e9f3ee;
}

.member-card strong,
.member-card span {
  display: block;
}

.member-card span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}

.profile-head {
  display: flex;
  align-items: center;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}

.profile-head img {
  width: 92px;
  height: 92px;
  border-radius: 8px;
  object-fit: cover;
  background: #d9e4df;
}

.profile-head p {
  margin-bottom: 4px;
  color: var(--muted);
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  margin-top: 18px;
}

.detail-grid div,
.emi-preview {
  min-height: 88px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.emi-preview {
  display: grid;
  align-content: center;
  gap: 7px;
}

.emi-preview span {
  color: var(--muted);
  font-weight: 700;
  font-size: 14px;
}

.emi-preview strong {
  font-size: 20px;
}

.emi-preview small {
  color: var(--muted);
  font-weight: 700;
  line-height: 1.35;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.form-grid.compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.date-range-filter {
  align-items: end;
  margin-bottom: 16px;
}

.member-report-search {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto auto;
  align-items: end;
  gap: 10px;
  margin-bottom: 16px;
}

.member-report-search .ghost-btn {
  min-width: 94px;
  width: auto;
}

.member-report-search span {
  align-self: center;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.date-range-filter .ghost-btn {
  min-height: 44px;
  width: 100%;
}

.group-settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.75fr);
  gap: 18px;
  align-items: start;
}

.group-settings-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.group-settings-form button[type="submit"] {
  width: min(260px, 100%);
}

@media (prefers-reduced-motion: reduce) {
  .public-scrolling-track {
    animation: none;
  }
}

.group-logo-control {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.group-logo-control .ghost-btn {
  width: auto;
  min-width: 150px;
}

.website-settings-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.website-settings-panel h3,
.website-settings-panel p {
  grid-column: 1 / -1;
  margin: 0;
}

.website-settings-panel p {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
}

.website-settings-panel textarea {
  min-height: 118px;
}

.committee-photo-manager {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(35, 102, 79, 0.18);
  border-radius: 8px;
  background: #ffffff;
}

.about-photo-manager {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(35, 102, 79, 0.18);
  border-radius: 8px;
  background: #ffffff;
}

.header-background-manager {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(35, 102, 79, 0.18);
  border-radius: 8px;
  background: #ffffff;
}

.header-background-preview {
  display: grid;
  place-items: center;
  min-height: 150px;
  overflow: hidden;
  border: 1px dashed rgba(35, 102, 79, 0.35);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(10, 38, 31, 0.78), rgba(17, 58, 70, 0.5)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center/cover;
  color: #ffffff;
  font-weight: 900;
  text-align: center;
}

.header-background-preview img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.header-background-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.header-background-actions .ghost-btn {
  width: auto;
  min-height: 38px;
}

.about-photo-preview {
  display: grid;
  place-items: center;
  min-height: 150px;
  overflow: hidden;
  border: 1px dashed rgba(35, 102, 79, 0.35);
  border-radius: 8px;
  background: #f8fbf9;
  color: var(--muted);
  font-weight: 900;
}

.about-photo-preview img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

.about-photo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.about-photo-actions .ghost-btn {
  width: auto;
  min-height: 38px;
}

.news-media-manager {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(35, 102, 79, 0.18);
  border-radius: 8px;
  background: #ffffff;
}

.news-media-preview {
  display: grid;
  place-items: center;
  min-height: 170px;
  overflow: hidden;
  border: 1px dashed rgba(35, 102, 79, 0.35);
  border-radius: 8px;
  background: #f8fbf9;
  color: var(--muted);
  font-weight: 900;
}

.news-media-preview img,
.news-media-preview video {
  width: 100%;
  max-height: 260px;
  display: block;
  object-fit: contain;
  background: #0d1b16;
}

.news-admin-media {
  width: 118px;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border: 1px solid rgba(35, 102, 79, 0.22);
  border-radius: 8px;
  background: #eef3f1;
}

.news-admin-media img,
.news-admin-media video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.committee-photo-manager-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.committee-photo-manager-title strong {
  color: var(--ink);
  font-size: 16px;
}

.committee-photo-manager-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-align: right;
}

.committee-photo-list {
  display: grid;
  gap: 8px;
}

.committee-photo-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.committee-photo-thumb {
  display: grid;
  place-items: center;
  width: 52px;
  height: 58px;
  overflow: hidden;
  border: 2px solid var(--green);
  border-radius: 8px;
  background: #ffffff;
  color: var(--green);
  font-weight: 900;
}

.committee-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.committee-photo-info {
  min-width: 0;
}

.committee-photo-info strong,
.committee-photo-info span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.committee-photo-info span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.committee-photo-upload {
  position: relative;
  display: inline-grid;
  place-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 6px;
  background: var(--green);
  color: #ffffff;
  font-weight: 900;
  white-space: nowrap;
  cursor: pointer;
}

.committee-photo-upload input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.committee-photo-remove {
  width: auto;
  min-width: 118px;
  min-height: 38px;
}

.security-settings {
  align-items: end;
  display: grid;
  gap: 12px;
  grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr)) auto;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.security-settings h3,
.security-settings p {
  margin: 0;
}

.security-status {
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.35;
}

.security-status.ok {
  color: var(--green);
}

.security-status.warning {
  color: #a15c00;
  font-weight: 800;
}

.security-settings .ghost-btn {
  min-width: 150px;
  width: auto;
}

.profile-settings-card {
  align-items: end;
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr) repeat(2, minmax(180px, 1fr)) auto;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.profile-avatar {
  align-self: center;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  color: var(--green);
  background: #e5f0eb;
  border: 1px solid rgba(35, 102, 79, 0.22);
}

.profile-avatar .nav-icon {
  width: 30px;
  height: 30px;
}

.profile-copy {
  align-self: center;
}

.profile-copy h3,
.profile-copy p {
  margin: 0;
}

.profile-copy p {
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.profile-settings-card .ghost-btn {
  min-width: 150px;
  width: auto;
}

.user-role-settings {
  display: grid;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.user-role-settings > div:first-child h3,
.user-role-settings > div:first-child p {
  margin: 0;
}

.user-role-settings > div:first-child p {
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.role-management-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.role-management-grid section {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(35, 102, 79, 0.16);
  border-radius: 8px;
  background: #ffffff;
}

.role-management-grid h4 {
  margin: 0;
  color: var(--ink);
}

.role-permission-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #ffffff;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.inline-check input {
  width: 16px;
  height: 16px;
  min-height: 0;
  padding: 0;
  flex: 0 0 auto;
}

.role-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.role-actions button {
  width: auto;
  min-width: 120px;
}

.role-list,
.staff-user-list {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
}

.role-list table,
.staff-user-list table {
  min-width: 560px;
}

.group-logo-preview,
.group-preview-logo {
  align-items: center;
  background: #eef3f1;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--green);
  display: flex;
  flex: 0 0 auto;
  font-weight: 900;
  justify-content: center;
  overflow: hidden;
}

.group-logo-preview {
  height: 72px;
  width: 72px;
}

.group-preview-logo {
  height: 96px;
  width: 96px;
}

.group-logo-preview img,
.group-preview-logo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.group-logo-preview span,
.group-preview-logo span {
  font-size: 34px;
}

.group-preview-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
  padding: 18px;
}

.group-preview-card h3 {
  margin: 14px 0 12px;
  color: var(--ink);
}

.group-preview-meta {
  display: grid;
  gap: 10px;
}

.group-preview-meta div {
  border-top: 1px solid var(--line);
  display: grid;
  gap: 4px;
  padding-top: 10px;
}

.group-preview-meta span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.group-preview-meta strong {
  color: var(--ink);
}

.saving-interest-history {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 10px;
  margin-top: 12px;
  padding: 14px;
}

.interest-history-title {
  color: var(--ink);
  font-weight: 900;
}

.interest-history-list {
  display: grid;
  gap: 8px;
}

.interest-history-row {
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 10px;
}

.interest-history-row.is-current {
  background: #eef7f2;
  border-color: rgba(35, 102, 79, 0.28);
}

.interest-history-row span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.interest-history-row strong {
  color: var(--green);
  font-size: 16px;
}

.share-range-hint {
  background: #f8fbf9;
  border: 1px dashed rgba(35, 102, 79, 0.3);
  border-radius: 8px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  margin: 0;
  padding: 10px 12px;
}

.search-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  grid-column: span 2;
  align-items: end;
}

.search-field .ghost-btn {
  width: auto;
  min-width: 92px;
}

label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-weight: 700;
  font-size: 14px;
}

input,
select,
textarea {
  width: 100%;
  min-height: 42px;
  padding: 9px 11px;
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 6px;
  background: white;
}

textarea {
  min-height: 92px;
  resize: vertical;
}

.application-form h3,
.full-field {
  grid-column: 1 / -1;
}

.application-form h3 {
  margin: 8px 0 0;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

form button,
.ghost-btn {
  min-height: 42px;
  align-self: end;
  width: 100%;
  padding: 0 16px;
  border-radius: 6px;
  background: var(--green);
  color: white;
  font-weight: 800;
  white-space: normal;
}

.ghost-btn {
  color: var(--green);
  background: #e7f0eb;
}

.data-table,
.mini-table {
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

th,
td {
  padding: 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

th {
  color: var(--muted);
  font-size: 13px;
}

.status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 99px;
  background: #e8f0f6;
  color: var(--blue);
  font-size: 13px;
  font-weight: 800;
}

.status.due {
  background: #faecec;
  color: var(--red);
}

.status.paid {
  background: #e8f3ee;
  color: var(--green);
}

.row-actions {
  display: flex;
  gap: 8px;
}

.row-actions button {
  min-height: 34px;
  padding: 0 10px;
  border-radius: 6px;
  background: #eef2f3;
  color: var(--ink);
}

.row-actions .view-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.notice-form {
  margin-bottom: 18px;
}

.notice-board {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.notice-list {
  display: grid;
  gap: 10px;
}

.notice-card {
  border: 1px solid var(--line);
  border-left: 4px solid var(--green);
  border-radius: 8px;
  background: #fbfdfb;
  padding: 12px 14px;
}

.notice-card div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 7px;
}

.notice-card strong {
  color: var(--ink);
  font-size: 16px;
}

.notice-card span,
.notice-message-preview {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.notice-card p {
  margin: 0;
  color: var(--ink);
  line-height: 1.55;
}

.notice-message-preview {
  display: block;
  max-width: 360px;
  line-height: 1.45;
}

.icon-eye {
  position: relative;
  width: 18px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 999px / 720px;
}

.icon-eye::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  transform: translate(-50%, -50%);
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 22px;
  background: rgba(10, 21, 25, 0.58);
}

.modal-backdrop.hidden {
  display: none;
}

.modal {
  width: min(920px, 100%);
  max-height: min(760px, calc(100vh - 44px));
  overflow: auto;
  padding: 22px;
  border-radius: 8px;
  background: white;
  box-shadow: var(--shadow);
}

.modal .panel-heading p {
  margin: 6px 0 0;
  color: var(--muted);
}

.document-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.document-grid article {
  min-width: 0;
}

.full-modal-section {
  grid-column: 1 / -1;
}

.document-preview {
  min-height: 260px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f6f8f8;
}

.document-preview img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
}

.signature-preview {
  min-height: 92px;
  display: grid;
  place-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.profile-document-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 10px;
}

.profile-document-grid article {
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
}

.profile-document-grid h4 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 14px;
}

.signature-preview img {
  max-width: 280px;
  max-height: 92px;
  object-fit: contain;
}

.member-loan-request {
  margin: 20px 0 6px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.member-loan-request .sub-heading {
  margin-bottom: 12px;
}

.member-loan-request .mini-table {
  margin-top: 14px;
}

.report-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.compact-report {
  grid-template-columns: repeat(2, 1fr);
  margin-top: 14px;
}

.report-grid article {
  min-height: 108px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.report-grid span {
  display: block;
  color: var(--muted);
}

.report-grid strong {
  display: block;
  margin-top: 10px;
  font-size: 22px;
}

.dashboard-grid article {
  position: relative;
  overflow: hidden;
}

.dashboard-grid article::after {
  content: "";
  position: absolute;
  right: 16px;
  bottom: 16px;
  width: 34px;
  height: 34px;
  border: 2px solid rgba(35, 102, 79, 0.22);
  border-radius: 8px;
}

.dashboard-board {
  display: grid;
  gap: 16px;
}

.dashboard-hero {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 2fr);
  gap: 14px;
}

.dashboard-total-card {
  display: flex;
  min-height: 184px;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  border: 1px solid rgba(16, 84, 57, 0.18);
  border-radius: 8px;
  color: white;
  background: #105439;
}

.dashboard-total-card span,
.dashboard-total-card p {
  color: rgba(255, 255, 255, 0.82);
  margin: 0;
}

.dashboard-total-card strong {
  display: block;
  margin: 12px 0;
  font-size: 32px;
  line-height: 1.1;
}

.dashboard-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.dashboard-metric,
.dashboard-progress-card,
.dashboard-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.dashboard-metric {
  min-height: 86px;
  padding: 14px;
  border-left: 4px solid #2f7a55;
}

.dashboard-metric span,
.dashboard-progress-card span,
.dashboard-panel-heading span,
.quick-action-grid span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.dashboard-metric strong {
  display: block;
  margin-top: 8px;
  font-size: 21px;
  line-height: 1.15;
}

.metric-interest,
.metric-paid {
  border-left-color: #b98a21;
}

.metric-loan,
.metric-due,
.metric-emi {
  border-left-color: #8f3f35;
}

.dashboard-progress-card {
  display: grid;
  grid-template-columns: minmax(220px, 0.7fr) minmax(220px, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 16px;
}

.dashboard-progress-card strong {
  display: block;
  margin-top: 5px;
  font-size: 20px;
}

.dashboard-progress-card p {
  margin: 0;
  color: var(--muted);
  font-weight: 700;
}

.dashboard-progress-track {
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: #e3ebe6;
}

.dashboard-progress-track i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: #1d6b49;
}

.dashboard-split {
  display: grid;
  grid-template-columns: minmax(280px, 0.85fr) minmax(0, 1.4fr);
  gap: 14px;
}

.dashboard-panel {
  min-width: 0;
  padding: 16px;
}

.dashboard-panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.dashboard-panel-heading h3 {
  margin: 0;
}

.quick-action-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.quick-action-grid button {
  min-height: 76px;
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  background: white;
  text-align: left;
}

.quick-action-grid button:hover {
  border-color: #88a99a;
  background: #f0f7f3;
}

.quick-action-grid strong {
  font-size: 15px;
}

.dashboard-recent table {
  font-size: 13px;
}

.dashboard-recent td,
.dashboard-recent th {
  padding: 10px 9px;
}

.empty {
  padding: 26px;
  color: var(--muted);
  border: 1px dashed var(--line);
  border-radius: 8px;
  text-align: center;
}

.receipt-box {
  display: grid;
  gap: 14px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.dues-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.dues-grid article {
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.dues-grid h3 {
  margin-top: 0;
}

.balance-sheet {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}

.balance-column {
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfcfc;
}

.balance-column h3 {
  margin-top: 0;
}

.balance-total {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 2px solid var(--line);
  font-weight: 900;
}

.certificate-picker {
  margin-bottom: 18px;
}

.share-certificate {
  min-height: 720px;
  padding: 18px;
  border: 6px double var(--green-dark);
  border-radius: 8px;
  background:
    radial-gradient(circle at 20% 20%, rgba(217, 151, 39, 0.09), transparent 28%),
    radial-gradient(circle at 80% 30%, rgba(35, 102, 79, 0.08), transparent 30%),
    repeating-linear-gradient(45deg, rgba(35, 102, 79, 0.035) 0 1px, transparent 1px 9px),
    white;
  box-shadow: inset 0 0 0 5px #c28a18, inset 0 0 0 12px rgba(35, 102, 79, 0.16);
}

.certificate-inner {
  position: relative;
  min-height: 680px;
  display: block;
  padding: 30px 44px;
  border: 2px solid var(--green-dark);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.8);
  overflow: hidden;
}

.certificate-inner::before,
.certificate-inner::after {
  content: "";
  position: absolute;
  width: 92px;
  height: 92px;
  border: 5px solid #b47b0b;
  opacity: 0.9;
}

.certificate-inner::before {
  left: -44px;
  top: -44px;
  transform: rotate(45deg);
}

.certificate-inner::after {
  right: -44px;
  bottom: -44px;
  transform: rotate(45deg);
}

.certificate-photo {
  position: absolute;
  left: 48px;
  top: 38px;
  width: 112px;
  height: 126px;
  border: 3px solid var(--green-dark);
  border-radius: 8px;
  object-fit: cover;
  background: #d9e4df;
}

.certificate-logo {
  position: absolute;
  left: 48px;
  top: 178px;
  width: 112px;
  height: 112px;
  display: grid;
  place-items: center;
  border: 4px double var(--green-dark);
  border-radius: 50%;
  color: var(--green-dark);
  font-weight: 900;
  text-align: center;
  line-height: 1.2;
  background: #f8fff9;
}

.certificate-number-box {
  position: absolute;
  right: 48px;
  top: 72px;
  min-width: 160px;
  padding: 12px 14px;
  border: 1px solid var(--green-dark);
  border-radius: 8px;
  text-align: center;
  background: #f8fff9;
}

.certificate-number-box span {
  display: block;
  color: var(--green-dark);
  font-weight: 900;
}

.certificate-number-box strong {
  display: block;
  margin-top: 4px;
  color: #d10f0f;
  font-size: 28px;
  letter-spacing: 4px;
}

.certificate-body h3 {
  margin: 0;
  color: var(--green-dark);
  font-size: 46px;
  text-align: center;
}

.certificate-body h2 {
  width: min(520px, 72%);
  margin: 24px auto 10px;
  padding: 10px 28px;
  color: white;
  border: 3px solid #c28a18;
  border-radius: 10px;
  background: linear-gradient(180deg, #0f653b, #063f26);
  font-size: 52px;
  text-align: center;
  box-shadow: 0 4px 10px rgba(6, 63, 38, 0.18);
}

.certificate-subtitle {
  margin: 4px 0;
  text-align: center;
  font-size: 18px;
  font-weight: 800;
}

.certificate-rate {
  margin: 6px 0 22px;
  color: var(--green-dark);
  text-align: center;
  font-size: 20px;
  font-weight: 900;
}

.certificate-line {
  margin: 12px 0;
  font-size: 19px;
  line-height: 1.8;
}

.certificate-fill {
  display: inline-block;
  min-width: 360px;
  padding: 0 10px 2px;
  border-bottom: 2px dotted #1f2c33;
  font-weight: 900;
}

.certificate-fill.short {
  min-width: 140px;
}

.certificate-fill.medium {
  min-width: 220px;
}

.certificate-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 430px;
  margin-top: 18px;
}

.certificate-facts div,
.certificate-sign {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fbfcfc;
}

.certificate-seal {
  position: absolute;
  left: 50%;
  bottom: 88px;
  width: 134px;
  height: 134px;
  display: grid;
  place-items: center;
  border: 10px solid #d8a927;
  border-radius: 50%;
  color: #8b650e;
  background: radial-gradient(circle, #fff6c9, #e5b843);
  font-weight: 900;
  text-align: center;
  transform: translateX(-50%);
}

.certificate-facts span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.certificate-facts strong {
  display: block;
  margin-top: 6px;
}

.certificate-footer {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 58px;
}

.certificate-sign {
  min-height: 78px;
  display: grid;
  align-content: end;
  border: 0;
  border-top: 2px solid var(--ink);
  border-radius: 0;
  background: transparent;
  text-align: center;
  font-weight: 900;
}

.receipt-title {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 12px;
}

.receipt-title h3 {
  margin: 0;
}

.receipt-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.receipt-grid div {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: white;
}

.receipt-grid span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.receipt-grid strong {
  display: block;
  margin-top: 6px;
}

@media (max-width: 900px) {
  .topbar {
    min-height: 250px;
    flex-direction: column;
  }

  .topbar-brand {
    gap: 12px;
  }

  .topbar-logo {
    flex-basis: 58px;
    width: 58px;
    height: 58px;
  }

  .top-actions {
    width: 100%;
    flex-direction: column;
  }

  main {
    width: min(100% - 20px, 1180px);
  }

  .summary-strip,
  .view-grid,
  .manager-layout,
  .admin-nav,
  .detail-grid,
  .group-settings-layout,
  .security-settings,
  .profile-settings-card,
  .role-management-grid,
  .form-grid,
  .form-grid.compact,
  .report-grid,
  .dashboard-hero,
  .dashboard-kpi-grid,
  .dashboard-progress-card,
  .dashboard-split,
  .quick-action-grid {
    grid-template-columns: 1fr;
  }

  .quick-actions-strip {
    grid-template-columns: repeat(4, minmax(64px, 1fr));
  }

  .quick-actions-strip > button {
    min-height: 68px;
  }

  .public-nav {
    position: static;
    align-items: flex-start;
    flex-direction: column;
  }

  .public-nav nav {
    justify-content: flex-start;
  }

  .public-hero {
    min-height: 460px;
    padding: 72px 20px 48px;
  }

  .public-info-list,
  .public-card-grid,
  .public-committee-grid,
  .public-check-list,
  .public-news-list,
  .public-ad-list,
  .public-notice-list {
    grid-template-columns: 1fr;
  }

  .public-ad-card {
    grid-column: auto;
    grid-template-columns: 1fr;
  }

  .public-ad-card:first-child {
    grid-column: auto;
    grid-template-columns: 1fr;
  }

  .profile-document-grid {
    grid-template-columns: 1fr;
  }

  .public-section,
  .public-section.public-band {
    width: 100%;
    padding: 38px 20px;
  }

  .public-about-section {
    grid-template-columns: 1fr;
  }

  .public-footer-grid {
    grid-template-columns: 1fr;
    width: calc(100% - 40px);
    padding: 34px 0 24px;
  }

  .public-footer-bottom {
    align-items: stretch;
    flex-direction: column;
    width: calc(100% - 40px);
  }

  .public-footer-bottom button {
    width: 100%;
  }

  .public-suggestion-card {
    grid-template-columns: 1fr;
  }

  .public-suggestion-actions {
    flex-direction: column;
  }

  .public-suggestion-actions button {
    width: 100%;
  }

  .about-photo-actions {
    flex-direction: column;
  }

  .header-background-actions {
    flex-direction: column;
  }

  .header-background-actions .committee-photo-upload,
  .header-background-actions .ghost-btn,
  .about-photo-actions .committee-photo-upload,
  .about-photo-actions .ghost-btn {
    width: 100%;
  }

  .member-report-search {
    grid-template-columns: 1fr;
  }

  .member-report-search .ghost-btn {
    width: 100%;
  }

  .role-switch {
    width: 100%;
  }

  .role-switch button {
    flex: 1;
  }

  .logout-btn {
    width: 100%;
  }

  .admin-nav {
    position: static;
    grid-column: 1;
    grid-row: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-nav button {
    min-height: 46px;
  }

  .manager-layout .admin-page,
  .manager-layout .wide {
    grid-column: 1;
  }

  .sub-heading {
    align-items: stretch;
    flex-direction: column;
  }

  .backup-actions,
  .online-sync-actions,
  .panel-actions,
  .search-field,
  .group-logo-control,
  .website-settings-panel,
  .dues-grid,
  .balance-sheet,
  .certificate-inner,
  .certificate-facts,
  .certificate-footer {
    grid-template-columns: 1fr;
  }

  .online-sync-actions,
  .backup-actions {
    justify-content: stretch;
  }

  .online-sync-actions input[type="password"],
  .online-sync-actions .ghost-btn,
  .online-sync-actions label,
  .backup-actions .ghost-btn {
    width: 100%;
  }

  .role-permission-list {
    grid-template-columns: 1fr;
  }

  .role-actions {
    flex-direction: column;
  }

  .role-actions button {
    width: 100%;
  }

  .website-settings-panel h3,
  .website-settings-panel p {
    grid-column: 1;
  }

  .committee-photo-manager-title,
  .committee-photo-row {
    align-items: stretch;
    grid-template-columns: 1fr;
  }

  .committee-photo-manager-title {
    display: grid;
  }

  .committee-photo-manager-title span {
    text-align: left;
  }

  .committee-photo-upload,
  .committee-photo-remove {
    width: 100%;
  }

  .share-certificate {
    padding: 10px;
  }

  .certificate-inner {
    padding: 210px 18px 24px;
  }

  .certificate-number-box {
    left: 48px;
    right: auto;
    top: 306px;
  }

  .certificate-body h3 {
    font-size: 30px;
  }

  .certificate-body h2 {
    width: 100%;
    font-size: 34px;
  }

  .certificate-fill,
  .certificate-fill.medium {
    min-width: 100%;
  }

  .certificate-facts {
    width: 100%;
  }

  .backup-actions .ghost-btn,
  .panel-actions .ghost-btn,
  .search-field .ghost-btn {
    width: 100%;
  }

  .group-logo-control {
    align-items: stretch;
    flex-direction: column;
  }

  .group-logo-control .ghost-btn {
    width: 100%;
  }

  .receipt-grid {
    grid-template-columns: 1fr;
  }

  .document-grid {
    grid-template-columns: 1fr;
  }
}

@media print {
  body {
    background: white;
  }

  .login-screen,
  .topbar,
  .role-switch,
  .admin-nav,
  .top-actions,
  form button,
  .ghost-btn,
  .logout-btn,
  .print-inline,
  #printBalanceSheet,
  .row-actions {
    display: none !important;
  }

  .modal-backdrop {
    display: none !important;
  }

  main {
    width: 100%;
    margin: 0;
  }

  .summary-strip,
  .view-grid,
  .manager-layout,
  .detail-grid,
  .report-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .panel,
  .summary-strip article {
    box-shadow: none;
    break-inside: avoid;
  }

  .hidden {
    display: none !important;
  }

  body.target-print * {
    visibility: hidden !important;
  }

  body.target-print .print-target,
  body.target-print .print-target * {
    visibility: visible !important;
  }

  body.target-print .print-target {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    padding: 0;
    border: 0;
    box-shadow: none;
  }

  body.target-print .print-title {
    display: block;
  }

  body.target-print .print-target form,
  body.target-print .print-target button,
  body.target-print .print-target .panel-heading button {
    display: none !important;
  }
}
.certificate-settings {
  margin-bottom: 18px;
  border-bottom: 1px solid #d8e4dc;
  padding-bottom: 18px;
}

.certificate-card {
  background: #fffaf0;
  border: 0;
  color: #122019;
  overflow-x: auto;
  padding: 0;
  position: relative;
  print-color-adjust: exact;
  -webkit-print-color-adjust: exact;
}

.certificate-border {
  border: 0;
  border-radius: 4px;
  background:
    repeating-linear-gradient(35deg, rgba(183, 131, 24, 0.035) 0 1px, transparent 1px 18px),
    repeating-linear-gradient(145deg, rgba(13, 90, 58, 0.03) 0 1px, transparent 1px 20px),
    #fffdf4;
  box-shadow:
    inset 0 0 0 2px #0d5a3a,
    inset 0 0 0 5px #fff8dc,
    inset 0 0 0 7px #b78318,
    inset 0 0 32px rgba(13, 90, 58, 0.08);
  min-height: 620px;
  min-width: 980px;
  overflow: hidden;
  padding: 66px 70px 56px;
  position: relative;
}

.certificate-border::before,
.certificate-border::after {
  content: "";
  pointer-events: none;
  position: absolute;
}

.certificate-border::before {
  background: url("certificate-frame.png") center / 100% 100% no-repeat;
  inset: 0;
  z-index: 2;
}

.certificate-border::after {
  border: 2px solid #0d5a3a;
  box-shadow:
    0 0 0 4px #fff8dc,
    0 0 0 7px #b78318;
  inset: 38px;
  z-index: 0;
}

.certificate-corner {
  display: none;
}

.certificate-border > :not(.certificate-corner) {
  position: relative;
  z-index: 1;
}

.certificate-header {
  display: block;
  min-height: 140px;
  padding: 8px 180px 0;
  position: relative;
  text-align: center;
}

.certificate-logo {
  align-items: center;
  border: 2px solid #2f6f56;
  border-radius: 999px;
  display: flex;
  height: 118px;
  justify-content: center;
  left: 32px;
  overflow: hidden;
  position: absolute;
  top: 0;
  width: 118px;
  background: #fffdf4;
}

.certificate-logo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.certificate-logo span {
  color: #2f6f56;
  font-size: 48px;
  font-weight: 800;
}

.certificate-header h2 {
  color: #0b5a35;
  font-size: 42px;
  line-height: 1.15;
  margin: 0;
  text-align: center;
  white-space: normal;
}

.certificate-header p,
.certificate-meta {
  margin: 4px 0 0;
}

.certificate-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  font-weight: 700;
}

.certificate-number-box {
  border: 1px solid #0d5a3a;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.75);
  color: #0d5a3a;
  padding: 10px;
  position: absolute;
  right: 18px;
  top: 62px;
  width: 160px;
}

.certificate-number-box span {
  display: block;
  font-weight: 700;
}

.certificate-number-box strong {
  color: #c81717;
  display: block;
  font-size: 25px;
  letter-spacing: 2px;
  margin-top: 5px;
}

.certificate-title {
  margin: 16px auto 24px;
  position: relative;
  text-align: center;
}

.certificate-title::before,
.certificate-title::after {
  content: none;
}

.certificate-title span {
  color: #0b5a35;
  display: block;
  font-size: 18px;
  font-weight: 700;
  margin-top: 8px;
}

.certificate-title strong {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.12), transparent 24%, transparent 76%, rgba(255, 255, 255, 0.12)),
    linear-gradient(#0e6a3f, #063d27);
  border: 4px solid #b78318;
  border-radius: 14px;
  box-shadow:
    0 0 0 5px #fff6d8,
    0 0 0 8px #b78318,
    0 8px 14px rgba(5, 45, 31, 0.18);
  color: #ffffff;
  display: inline-block;
  font-size: 40px;
  min-width: 430px;
  padding: 8px 44px 10px;
  position: relative;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.18);
  z-index: 1;
}

.certificate-lines {
  margin: 0 270px 18px 0;
  max-width: none;
}

.certificate-lines p {
  align-items: baseline;
  display: grid;
  gap: 12px;
  grid-template-columns: 160px 12px 1fr;
  margin: 10px 0;
}

.certificate-lines span,
.certificate-lines b {
  font-size: 18px;
}

.certificate-lines strong {
  border-bottom: 2px dotted #222;
  display: block;
  font-size: 18px;
  min-height: 30px;
  padding-left: 10px;
}

.certificate-member-photo {
  background: #fffdf4;
  border: 2px solid #0d5a3a;
  box-shadow: 0 0 0 4px rgba(183, 131, 24, 0.18);
  height: 136px;
  padding: 6px;
  position: absolute;
  right: 40px;
  top: -40px;
  width: 116px;
}

.certificate-member-photo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.certificate-statement {
  font-size: 18px;
  line-height: 1.8;
  margin: 18px auto 26px;
  max-width: 980px;
  text-align: left;
}

.certificate-middle {
  align-items: center;
  display: grid;
  gap: 34px;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 72px;
}

.certificate-middle .certificate-seal {
  display: none;
}

.certificate-table {
  border-collapse: collapse;
  width: 100%;
}

.certificate-table th,
.certificate-table td {
  border: 1px solid #204d39;
  font-size: 17px;
  padding: 10px 14px;
  text-align: left;
}

.certificate-table th {
  font-weight: 700;
  width: 44%;
}

.certificate-seal {
  align-items: center;
  background: transparent;
  border: 1px dashed #0d5a3a;
  border-radius: 4px;
  color: #285336;
  display: flex;
  font-size: 12px;
  font-weight: 800;
  flex: 0 0 86px;
  height: 34px;
  justify-content: center;
  outline: none;
  padding: 0 6px;
  text-align: center;
  width: 86px;
}

.certificate-note {
  font-size: 18px;
  line-height: 1.65;
  margin: 58px 0 0;
  padding-bottom: 34px;
}

.certificate-footer {
  align-items: flex-start;
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  bottom: 14px;
  left: 48px;
  margin-top: 0;
  padding: 0;
  position: absolute;
  right: 48px;
  text-align: center;
}

.certificate-footer > div {
  min-width: 0;
}

.certificate-footer span {
  border-top: 1px solid #173f32;
  display: block;
  height: 1px;
  margin: 0 auto;
  width: 120px;
}

.certificate-footer p,
.certificate-footer::after {
  color: #0d5a3a;
  display: block;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
  margin: 7px 0 0;
  white-space: nowrap;
}

.certificate-footer::after {
  content: "संस्थाको छाप";
  margin-top: 8px;
}

@media (max-width: 900px) {
  .certificate-border {
    min-width: 980px;
  }

  .certificate-lines strong {
    padding-left: 0;
  }

  .certificate-footer {
    display: flex;
  }
}
.receipt-paper {
  background: #fffdf6;
  border: 2px solid #0d5a3a;
  box-shadow: inset 0 0 0 4px #d9b15f;
  color: #143528;
  margin: 0 auto;
  max-width: 760px;
  padding: 24px;
}

.transaction-list {
  margin-bottom: 18px;
}

.transaction-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.transaction-actions button {
  align-items: center;
  background: #f7fbf8;
  border: 1px solid #b9cec1;
  border-radius: 6px;
  color: #0d5a3a;
  cursor: pointer;
  display: inline-flex;
  font-size: 16px;
  font-weight: 800;
  height: 30px;
  justify-content: center;
  line-height: 1;
  width: 30px;
}

.transaction-actions button:hover {
  background: #e7f2eb;
}

.audit-log-list {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.audit-log-list table td:nth-child(4) {
  min-width: 280px;
}

.trial-balance-heading {
  margin-top: 18px;
}

.trial-balance {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.trial-balance-heading .panel-actions {
  align-items: center;
}

.trial-balance-heading .panel-actions span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.trial-balance table td:nth-child(2),
.trial-balance table td:nth-child(3) {
  font-weight: 900;
  white-space: nowrap;
}

.saving-ledger-summary {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}

.saving-ledger-statement table td,
.saving-ledger-statement table th {
  white-space: nowrap;
}

.ledger-statement {
  display: grid;
  gap: 18px;
}

.ledger-print-header {
  align-items: center;
  border: 2px solid #0d5a3a;
  display: grid;
  gap: 14px;
  grid-template-columns: 72px 1fr;
  padding: 14px;
  text-align: center;
}

.ledger-print-logo {
  align-items: center;
  border: 2px solid #0d5a3a;
  border-radius: 999px;
  display: flex;
  height: 62px;
  justify-content: center;
  overflow: hidden;
  width: 62px;
}

.ledger-print-logo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ledger-print-logo span {
  color: #0d5a3a;
  font-size: 26px;
  font-weight: 800;
}

.ledger-print-header h2 {
  color: #0d5a3a;
  margin: 0;
}

.ledger-print-header p {
  margin: 3px 0 0;
}

.ledger-header {
  align-items: center;
  border-bottom: 2px solid #0d5a3a;
  display: flex;
  justify-content: space-between;
  padding-bottom: 12px;
}

.ledger-header h3 {
  color: #0d5a3a;
  margin: 0;
}

.ledger-header p {
  margin: 4px 0 0;
}

.ledger-print-footer {
  display: grid;
  gap: 34px;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 54px;
  text-align: center;
}

.ledger-print-footer span {
  border-top: 1px solid #143528;
  display: block;
}

.ledger-print-footer p {
  color: #0d5a3a;
  font-weight: 800;
  margin: 7px 0 0;
}

.ledger-loan {
  display: grid;
  gap: 12px;
}

.ledger-summary {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ledger-summary article {
  border: 1px solid #c8d8cd;
  padding: 10px;
}

.ledger-summary span {
  color: #5f746a;
  display: block;
  font-size: 13px;
}

.ledger-summary strong {
  display: block;
  margin-top: 4px;
}

.loan-application-picker {
  margin-bottom: 14px;
}

.loan-application-form {
  overflow-x: auto;
  padding-bottom: 8px;
}

.loan-application-sheet {
  position: relative;
  width: 820px;
  min-height: 1120px;
  padding: 26px;
  border: 2px solid #173b7a;
  border-radius: 6px;
  background:
    repeating-linear-gradient(35deg, rgba(23, 59, 122, 0.025) 0 1px, transparent 1px 18px),
    #ffffff;
  box-shadow: inset 0 0 0 4px #ffffff, inset 0 0 0 6px rgba(23, 59, 122, 0.32), 0 18px 50px rgba(19, 40, 68, 0.12);
  color: #173b7a;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  print-color-adjust: exact;
  -webkit-print-color-adjust: exact;
}

.loan-app-corner {
  position: absolute;
  width: 54px;
  height: 54px;
  pointer-events: none;
}

.corner-top-left {
  top: 6px;
  left: 6px;
  border-top: 3px solid #173b7a;
  border-left: 3px solid #173b7a;
  border-radius: 10px 0 0;
}

.corner-top-right {
  top: 6px;
  right: 6px;
  border-top: 3px solid #173b7a;
  border-right: 3px solid #173b7a;
  border-radius: 0 10px 0 0;
}

.corner-bottom-left {
  bottom: 6px;
  left: 6px;
  border-bottom: 3px solid #173b7a;
  border-left: 3px solid #173b7a;
  border-radius: 0 0 0 10px;
}

.corner-bottom-right {
  right: 6px;
  bottom: 6px;
  border-right: 3px solid #173b7a;
  border-bottom: 3px solid #173b7a;
  border-radius: 0 0 10px;
}

.loan-app-header {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr) 184px;
  gap: 14px;
  align-items: start;
  margin-bottom: 12px;
}

.loan-app-logo,
.loan-app-photo {
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 2px solid #173b7a;
  background: #ffffff;
  text-align: center;
}

.loan-app-logo {
  width: 104px;
  height: 104px;
  border-radius: 50%;
  font-size: 28px;
}

.loan-app-logo img,
.loan-app-photo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.loan-app-title {
  text-align: center;
}

.loan-app-title h2 {
  margin: 0 0 8px;
  color: #123776;
  font-size: 44px;
  line-height: 1;
  letter-spacing: 0;
}

.loan-app-title p {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 5px 0;
}

.loan-app-side {
  display: grid;
  gap: 10px;
}

.loan-app-meta {
  padding: 8px;
  border: 1px solid #173b7a;
  border-radius: 6px;
}

.loan-app-meta .loan-app-field {
  grid-template-columns: 82px 8px minmax(0, 1fr);
}

.loan-app-meta .loan-app-line {
  min-width: 0;
  width: 100%;
}

.loan-app-photo {
  justify-self: end;
  width: 148px;
  height: 118px;
  font-size: 13px;
}

.loan-app-section-title {
  display: inline-block;
  margin: 8px 0 0;
  padding: 6px 16px;
  border-radius: 6px 6px 0 0;
  background: #123776;
  color: #ffffff;
  font-size: 16px;
}

.loan-app-details,
.loan-app-grid-split {
  border: 1px solid #173b7a;
}

.loan-app-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.loan-app-details > div {
  min-width: 0;
  padding: 9px 12px;
}

.loan-app-details > div + div {
  border-left: 1px solid #173b7a;
}

.loan-app-field {
  display: grid;
  grid-template-columns: 134px 10px minmax(0, 1fr);
  align-items: end;
  gap: 6px;
  margin: 5px 0;
}

.loan-app-field strong {
  color: #173b7a;
}

.loan-app-field b {
  text-align: center;
}

.loan-app-line {
  display: inline-block;
  min-width: 92px;
  min-height: 18px;
  padding: 0 5px 1px;
  border-bottom: 2px dotted #173b7a;
  color: #142341;
  vertical-align: bottom;
}

.loan-app-title .loan-app-line {
  min-width: 270px;
}

.loan-app-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.loan-app-check {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin: 3px 12px 3px 0;
  white-space: nowrap;
}

.loan-app-check i {
  width: 13px;
  height: 13px;
  border: 1.8px solid #173b7a;
  background: #ffffff;
}

.loan-app-check.checked i {
  position: relative;
}

.loan-app-check.checked i::after {
  content: "✓";
  position: absolute;
  left: 1px;
  top: -7px;
  color: #123776;
  font-size: 18px;
  font-weight: 900;
}

.loan-app-installment-note {
  display: inline-block;
  margin-top: 5px;
  color: #142341;
}

.loan-app-table {
  width: 100%;
  min-width: 0;
  border-collapse: collapse;
  border: 1px solid #173b7a;
  color: #173b7a;
  table-layout: fixed;
}

.loan-app-table th,
.loan-app-table td {
  padding: 8px 10px;
  border: 1px solid #173b7a;
  vertical-align: top;
}

.loan-app-table th {
  text-align: center;
}

.loan-app-grid-split {
  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(0, 1.25fr);
  margin-top: 8px;
}

.loan-app-grid-split > div {
  min-width: 0;
  padding: 8px 10px;
}

.loan-app-grid-split > div + div {
  border-left: 1px solid #173b7a;
}

.loan-app-collateral {
  display: grid;
  gap: 6px;
  margin-top: 8px;
}

.loan-app-note-lines {
  display: grid;
  gap: 7px;
  margin-top: 8px;
}

.loan-app-note-lines .loan-app-line,
.loan-app-remarks .loan-app-line {
  width: 100%;
}

.guarantor-table th:first-child {
  width: 76px;
}

.loan-app-declaration {
  margin: 0;
  padding: 9px 12px;
  border: 1px solid #173b7a;
  color: #142341;
}

.loan-app-sign-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  padding: 7px 12px;
  border: 1px solid #173b7a;
  border-top: 0;
}

.office-table th,
.office-table td {
  text-align: center;
}

.loan-app-remarks {
  margin: 0;
  padding: 7px 10px;
  border: 1px solid #173b7a;
  border-top: 0;
}

.loan-app-footer {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: 26px;
  align-items: center;
  margin-top: 10px;
}

.loan-app-officers {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border: 1px solid #173b7a;
}

.loan-app-officers > div {
  padding: 8px 12px;
  min-height: 96px;
}

.loan-app-officers > div + div {
  border-left: 1px solid #173b7a;
}

.loan-app-officers strong {
  display: block;
  margin-bottom: 6px;
  text-align: center;
}

.loan-app-stamp {
  display: grid;
  place-items: center;
  width: 126px;
  height: 126px;
  border: 2px dashed #173b7a;
  border-radius: 50%;
  text-align: center;
}

.membership-application-form {
  display: none;
}

.membership-app-sheet {
  box-sizing: border-box;
  width: 820px;
  min-height: 1120px;
  padding: 26px;
  border: 5px solid #0d4f2a;
  background:
    repeating-linear-gradient(36deg, rgba(13, 79, 42, 0.035) 0 1px, transparent 1px 18px),
    #ffffff;
  box-shadow: inset 0 0 0 5px #ffffff, inset 0 0 0 7px rgba(13, 79, 42, 0.46);
  color: #103c26;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.36;
  print-color-adjust: exact;
  -webkit-print-color-adjust: exact;
}

.membership-app-header {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr) 136px;
  gap: 18px;
  align-items: start;
  padding-bottom: 12px;
  border-bottom: 2px solid #103c26;
}

.membership-app-logo,
.membership-app-photo {
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 2px solid #103c26;
  background: #ffffff;
  text-align: center;
}

.membership-app-logo {
  width: 124px;
  height: 124px;
  border-radius: 50%;
  font-size: 34px;
}

.membership-app-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.membership-app-photo {
  justify-self: end;
  width: 126px;
  height: 154px;
  border-radius: 6px;
  color: #1c3528;
  font-size: 14px;
}

.membership-app-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.membership-app-title {
  text-align: center;
}

.membership-app-title h1 {
  margin: 2px 0 2px;
  color: #0f5a2f;
  font-size: 46px;
  line-height: 1.06;
  letter-spacing: 0;
}

.membership-app-title p {
  margin: 2px 0 8px;
}

.membership-app-title h2 {
  display: inline-block;
  margin: 8px 0 0;
  padding: 10px 28px;
  border-radius: 8px;
  background: linear-gradient(180deg, #0f6b3b, #073f24);
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.24);
  color: #ffffff;
  font-size: 31px;
  line-height: 1;
}

.membership-app-section-title {
  display: inline-block;
  margin: 10px 0 0;
  padding: 6px 15px;
  border-radius: 6px 6px 0 0;
  background: linear-gradient(180deg, #0f6b3b, #073f24);
  color: #ffffff;
  font-size: 16px;
}

.membership-app-details,
.membership-app-address-grid,
.membership-app-info-grid,
.membership-app-recommender,
.membership-app-declaration,
.membership-app-sign-row {
  border: 1px solid #103c26;
}

.membership-app-details.two-col,
.membership-app-address-grid,
.membership-app-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.membership-app-details > div,
.membership-app-address-grid > div,
.membership-app-info-grid > div,
.membership-app-recommender,
.membership-app-declaration,
.membership-app-sign-row {
  min-width: 0;
  padding: 9px 12px;
}

.membership-app-details > div + div,
.membership-app-address-grid > div + div,
.membership-app-info-grid > div + div {
  border-left: 1px solid #103c26;
}

.membership-app-field {
  display: grid;
  grid-template-columns: 132px 10px minmax(0, 1fr);
  align-items: end;
  gap: 6px;
  margin: 6px 0;
}

.membership-app-field strong {
  color: #143b27;
}

.membership-app-field b {
  text-align: center;
}

.membership-app-line {
  display: inline-block;
  min-width: 94px;
  min-height: 19px;
  padding: 0 5px 1px;
  border-bottom: 2px dotted #103c26;
  color: #101f17;
  vertical-align: bottom;
}

.membership-app-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
  align-items: center;
}

.membership-app-check {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

.membership-app-check i {
  width: 13px;
  height: 13px;
  border: 1.8px solid #103c26;
  background: #ffffff;
}

.membership-app-check.checked i {
  position: relative;
}

.membership-app-check.checked i::after {
  content: "\2713";
  position: absolute;
  left: 1px;
  top: -7px;
  color: #0f5a2f;
  font-size: 18px;
  font-weight: 900;
}

.membership-app-recommender {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 14px;
}

.membership-app-recommender .membership-app-field,
.membership-app-sign-row .membership-app-field,
.membership-app-office-grid .membership-app-field {
  grid-template-columns: auto 7px minmax(0, 1fr);
}

.membership-app-declaration {
  margin: 0;
  color: #101f17;
}

.membership-app-sign-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  border-top: 0;
}

.membership-app-office {
  margin-top: 12px;
  padding: 12px 16px;
  border: 1.5px solid #103c26;
  border-radius: 8px;
}

.membership-app-office h3 {
  margin: 0 0 8px;
  color: #0f5a2f;
  text-align: center;
}

.membership-app-office-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 18px;
}

.membership-app-office p {
  margin: 8px 0 0;
  text-align: center;
}

#printOnlyArea {
  display: none;
}

@media print {
  @page {
    margin: 10mm;
    size: auto;
  }

  @page certificate {
    margin: 6mm;
    size: A4 landscape;
  }

  @page loan-application {
    margin: 5mm;
    size: A4 portrait;
  }

  @page membership-application {
    margin: 5mm;
    size: A4 portrait;
  }

  body.certificate-print {
    width: 285mm !important;
  }

  body.certificate-print .print-target {
    height: 198mm !important;
    overflow: hidden !important;
    page: certificate;
    width: 285mm !important;
  }

  body.certificate-print .certificate-card {
    height: 198mm !important;
    overflow: hidden !important;
    padding: 0 !important;
    width: 285mm !important;
  }

  body.certificate-print .certificate-border {
    box-sizing: border-box !important;
    border: 0 !important;
    min-height: 0 !important;
    min-width: 0 !important;
    height: 198mm !important;
    padding: 14mm 16mm 10mm !important;
    width: 285mm !important;
  }

  body.certificate-print .certificate-header h2 {
    font-size: 28pt !important;
  }

  body.certificate-print .certificate-title strong {
    font-size: 24pt !important;
  }

  body.certificate-print .certificate-logo {
    height: 30mm !important;
    width: 30mm !important;
  }

  body.certificate-print .certificate-number-box {
    right: 12mm !important;
    top: 24mm !important;
  }

  body.certificate-print .certificate-member-photo {
    height: 35mm !important;
    right: 18mm !important;
    top: -8mm !important;
    width: 30mm !important;
  }

  body.certificate-print .certificate-lines {
    margin-right: 68mm !important;
  }

  body.certificate-print .certificate-header {
    min-height: 25mm !important;
    padding-top: 0 !important;
  }

  body.certificate-print .certificate-title {
    margin: 3mm auto 3mm !important;
  }

  body.certificate-print .certificate-lines p {
    margin: 2mm 0 !important;
  }

  body.certificate-print .certificate-statement {
    font-size: 12pt !important;
    line-height: 1.35 !important;
    margin: 2mm 4mm 3mm 0 !important;
  }

  body.certificate-print .certificate-middle {
    align-items: start !important;
    gap: 7mm !important;
    margin-bottom: 18mm !important;
    grid-template-columns: 1.35fr 0.85fr !important;
  }

  body.certificate-print .certificate-table th,
  body.certificate-print .certificate-table td {
    font-size: 11pt !important;
    padding: 2mm 3mm !important;
  }

  body.certificate-print .certificate-footer {
    bottom: 4mm !important;
    left: 14mm !important;
    margin-top: 0 !important;
    right: 14mm !important;
  }

  body.certificate-print .certificate-note {
    font-size: 12pt !important;
    line-height: 1.35 !important;
    margin-top: 12mm !important;
    padding-bottom: 14mm !important;
  }

  body.loan-application-print {
    width: 200mm !important;
  }

  body.loan-application-print .print-target {
    page: loan-application;
    width: 200mm !important;
  }

  body.loan-application-print .loan-application-form {
    overflow: visible !important;
    padding: 0 !important;
  }

  body.loan-application-print .loan-application-sheet {
    width: 200mm !important;
    min-height: 287mm !important;
    padding: 4mm !important;
    border: 1.6pt solid #173b7a !important;
    border-radius: 0 !important;
    box-shadow: inset 0 0 0 2pt #ffffff, inset 0 0 0 3pt rgba(23, 59, 122, 0.32) !important;
    font-size: 6.9pt !important;
  }

  body.loan-application-print .loan-app-header {
    grid-template-columns: 23mm minmax(0, 1fr) 46mm !important;
    gap: 3mm !important;
    margin-bottom: 2mm !important;
  }

  body.loan-application-print .loan-app-logo {
    width: 23mm !important;
    height: 23mm !important;
  }

  body.loan-application-print .loan-app-title h2 {
    font-size: 23pt !important;
    margin-bottom: 1.5mm !important;
  }

  body.loan-application-print .loan-app-title p {
    margin: 1mm 0 !important;
  }

  body.loan-application-print .loan-app-title .loan-app-line {
    min-width: 42mm !important;
  }

  body.loan-application-print .loan-app-side {
    gap: 2mm !important;
  }

  body.loan-application-print .loan-app-meta {
    padding: 1.2mm !important;
    font-size: 7.8pt !important;
  }

  body.loan-application-print .loan-app-meta .loan-app-field {
    grid-template-columns: 17mm 2mm minmax(0, 1fr) !important;
  }

  body.loan-application-print .loan-app-meta .loan-app-line {
    min-width: 0 !important;
    width: 100% !important;
  }

  body.loan-application-print .loan-app-photo {
    width: 37mm !important;
    height: 25mm !important;
    font-size: 6.8pt !important;
  }

  body.loan-application-print .loan-app-section-title {
    margin-top: 1.2mm !important;
    padding: 1.1mm 3mm !important;
    font-size: 7.8pt !important;
  }

  body.loan-application-print .loan-app-details > div,
  body.loan-application-print .loan-app-grid-split > div,
  body.loan-application-print .loan-app-table th,
  body.loan-application-print .loan-app-table td {
    padding: 1.2mm 1.6mm !important;
  }

  body.loan-application-print .loan-app-field {
    grid-template-columns: 25mm 2mm minmax(0, 1fr) !important;
    gap: 1mm !important;
    margin: 0.45mm 0 !important;
  }

  body.loan-application-print .loan-app-line {
    min-height: 3.4mm !important;
    border-bottom-width: 1pt !important;
  }

  body.loan-application-print .loan-app-check {
    gap: 1.2mm !important;
    margin: 0.35mm 2mm 0.35mm 0 !important;
  }

  body.loan-application-print .loan-app-check i {
    width: 3mm !important;
    height: 3mm !important;
  }

  body.loan-application-print .loan-app-check.checked i::after {
    left: 0.2mm !important;
    top: -1.8mm !important;
    font-size: 10pt !important;
  }

  body.loan-application-print .loan-app-grid-split {
    grid-template-columns: minmax(0, 0.66fr) minmax(0, 1.34fr) !important;
    margin-top: 1.5mm !important;
  }

  body.loan-application-print .guarantor-table th:first-child {
    width: 15mm !important;
  }

  body.loan-application-print .loan-app-declaration,
  body.loan-application-print .loan-app-sign-row,
  body.loan-application-print .loan-app-remarks {
    padding: 1.2mm 1.6mm !important;
  }

  body.loan-application-print .loan-app-footer {
    grid-template-columns: 1fr 26mm !important;
    gap: 4mm !important;
    margin-top: 2mm !important;
  }

  body.loan-application-print .loan-app-officers > div {
    min-height: 18mm !important;
    padding: 1.2mm 1.6mm !important;
  }

  body.loan-application-print .loan-app-stamp {
    width: 24mm !important;
    height: 24mm !important;
  }

  body.membership-application-print {
    width: 200mm !important;
  }

  body.membership-application-print .print-target {
    page: membership-application;
    width: 200mm !important;
  }

  body.membership-application-print #printOnlyArea .membership-application-form {
    display: block !important;
    overflow: visible !important;
    padding: 0 !important;
  }

  body.membership-application-print .membership-app-sheet {
    width: 200mm !important;
    min-height: 287mm !important;
    padding: 5mm !important;
    border: 1.8pt solid #0d4f2a !important;
    box-shadow: inset 0 0 0 2.2pt #ffffff, inset 0 0 0 3.4pt rgba(13, 79, 42, 0.46) !important;
    font-size: 7.2pt !important;
  }

  body.membership-application-print .membership-app-header {
    grid-template-columns: 25mm minmax(0, 1fr) 27mm !important;
    gap: 4mm !important;
    padding-bottom: 2mm !important;
  }

  body.membership-application-print .membership-app-logo {
    width: 24mm !important;
    height: 24mm !important;
  }

  body.membership-application-print .membership-app-photo {
    width: 26mm !important;
    height: 31mm !important;
    font-size: 6.6pt !important;
  }

  body.membership-application-print .membership-app-title h1 {
    font-size: 23pt !important;
    margin: 0 !important;
  }

  body.membership-application-print .membership-app-title p {
    margin: 0.5mm 0 1mm !important;
  }

  body.membership-application-print .membership-app-title h2 {
    padding: 2.2mm 8mm !important;
    font-size: 16pt !important;
  }

  body.membership-application-print .membership-app-section-title {
    margin-top: 1.4mm !important;
    padding: 1.2mm 3.4mm !important;
    font-size: 7.8pt !important;
  }

  body.membership-application-print .membership-app-details > div,
  body.membership-application-print .membership-app-address-grid > div,
  body.membership-application-print .membership-app-info-grid > div,
  body.membership-application-print .membership-app-recommender,
  body.membership-application-print .membership-app-declaration,
  body.membership-application-print .membership-app-sign-row,
  body.membership-application-print .membership-app-office {
    padding: 1.3mm 1.8mm !important;
  }

  body.membership-application-print .membership-app-field {
    grid-template-columns: 28mm 2mm minmax(0, 1fr) !important;
    gap: 1mm !important;
    margin: 0.55mm 0 !important;
  }

  body.membership-application-print .membership-app-line {
    min-height: 3.3mm !important;
    border-bottom-width: 1pt !important;
  }

  body.membership-application-print .membership-app-checks {
    gap: 2.5mm !important;
  }

  body.membership-application-print .membership-app-check i {
    width: 2.8mm !important;
    height: 2.8mm !important;
  }

  body.membership-application-print .membership-app-recommender {
    grid-template-columns: 2fr 1fr 1fr 1fr !important;
    gap: 3mm !important;
  }

  body.membership-application-print .membership-app-sign-row {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 4mm !important;
  }

  body.membership-application-print .membership-app-office {
    margin-top: 2mm !important;
    border-radius: 1.5mm !important;
  }

  body.membership-application-print .membership-app-office h3 {
    margin-bottom: 1mm !important;
  }

  body.membership-application-print .membership-app-office p {
    margin-top: 1mm !important;
  }

  html,
  body {
    background: #ffffff !important;
    height: auto !important;
    margin: 0 !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  body.target-print > *:not(#printOnlyArea) {
    display: none !important;
  }

  #printOnlyArea {
    display: block !important;
    margin: 0 auto !important;
    padding: 0 !important;
    visibility: visible !important;
  }

  #printOnlyArea,
  #printOnlyArea * {
    visibility: visible !important;
  }

  body.target-print .print-target {
    background: #ffffff !important;
    display: block !important;
    margin: 0 auto !important;
    max-height: none !important;
    min-height: 0 !important;
    overflow: visible !important;
    page-break-after: avoid !important;
    page-break-before: avoid !important;
    page-break-inside: avoid !important;
    width: 100% !important;
  }

  #printOnlyArea .receipt-paper {
    max-width: 180mm !important;
    padding: 8mm !important;
  }

  #printOnlyArea .receipt-header h3 {
    font-size: 18pt !important;
  }

  #printOnlyArea .receipt-title {
    margin: 6mm 0 !important;
  }

  #printOnlyArea .receipt-grid {
    gap: 3mm !important;
  }

  #printOnlyArea .receipt-footer {
    margin-top: 18mm !important;
  }

  #printOnlyArea .ledger-statement {
    gap: 8mm !important;
  }

  #printOnlyArea .date-range-filter {
    display: none !important;
  }

  #printOnlyArea .ledger-print-header {
    padding: 5mm !important;
  }

  #printOnlyArea .ledger-summary {
    grid-template-columns: repeat(4, 1fr) !important;
  }

  #printOnlyArea .ledger-print-footer {
    margin-top: 18mm !important;
  }

  .receipt-paper {
    box-shadow: none !important;
    page-break-after: avoid !important;
    page-break-before: avoid !important;
    page-break-inside: avoid !important;
  }

  .certificate-card,
  .certificate-border {
    page-break-after: avoid !important;
    page-break-before: avoid !important;
    page-break-inside: avoid !important;
    print-color-adjust: exact !important;
    -webkit-print-color-adjust: exact !important;
  }
}

.receipt-header {
  align-items: center;
  border-bottom: 1px solid #c9d8ce;
  display: grid;
  gap: 16px;
  grid-template-columns: 72px 1fr;
  padding-bottom: 14px;
  text-align: center;
}

.receipt-logo {
  align-items: center;
  border: 2px solid #0d5a3a;
  border-radius: 999px;
  display: flex;
  height: 64px;
  justify-content: center;
  overflow: hidden;
  width: 64px;
}

.receipt-logo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.receipt-logo span {
  color: #0d5a3a;
  font-size: 26px;
  font-weight: 800;
}

.admin-finance-overview {
  margin: 0 0 20px;
}

.admin-finance-overview-heading {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
}

.admin-finance-overview-heading h3 {
  margin: 0 0 3px;
}

.admin-finance-overview-heading span {
  color: var(--muted);
  font-size: 13px;
}

.admin-finance-overview-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-finance-card {
  border: 1px solid #d4e0da;
  border-left: 4px solid #247252;
  border-radius: 6px;
  display: grid;
  gap: 7px;
  min-height: 116px;
  padding: 15px 16px;
}

.admin-finance-card span,
.admin-finance-card small {
  color: var(--muted);
}

.admin-finance-card strong {
  color: #10251c;
  font-size: 24px;
}

.admin-finance-card.expense,
.admin-finance-card.loss {
  border-left-color: #a34238;
}

.admin-finance-card.profit,
.admin-finance-card.income,
.admin-finance-card.other-income {
  border-left-color: #247252;
}

.admin-finance-card.savings {
  border-left-color: #176a94;
}

.admin-finance-card.interest {
  border-left-color: #c48a20;
}

@media (max-width: 900px) {
  .admin-finance-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .admin-finance-overview-grid {
    grid-template-columns: 1fr;
  }
}

.membership-app-signature-line {
  align-items: center;
  display: flex;
  justify-content: center;
  min-height: 42px;
  padding: 2px 0;
}

.membership-app-signature-line img {
  display: block;
  max-height: 38px;
  max-width: 100%;
  object-fit: contain;
}

@media print {
  body.membership-application-print .membership-app-signature-line {
    min-height: 9mm !important;
    padding: 0 !important;
  }

  body.membership-application-print .membership-app-signature-line img {
    max-height: 8.5mm !important;
  }
}

.receipt-header h3 {
  color: #0d5a3a;
  font-size: 24px;
  margin: 0;
}

.receipt-header p {
  margin: 3px 0 0;
}

.receipt-title {
  align-items: center;
  background: #0d5a3a;
  color: #ffffff;
  display: flex;
  justify-content: space-between;
  margin: 18px 0;
  padding: 10px 14px;
}

.receipt-title h3,
.receipt-title strong {
  margin: 0;
}

.receipt-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.receipt-grid div {
  border: 1px solid #c9d8ce;
  padding: 10px 12px;
}

.receipt-grid span {
  color: #5f746a;
  display: block;
  font-size: 13px;
}

.receipt-grid strong {
  display: block;
  margin-top: 4px;
}

.receipt-footer {
  display: grid;
  gap: 28px;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 46px;
  text-align: center;
}

.receipt-footer span {
  border-top: 1px solid #143528;
  display: block;
  height: 1px;
}

.receipt-footer p {
  color: #0d5a3a;
  font-weight: 800;
  margin: 7px 0 0;
}

.register-page {
  min-height: 100vh;
  background: #eef3f1;
}

.register-header {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 82px;
  padding: 12px min(5vw, 64px);
  border-bottom: 3px solid rgba(217, 151, 39, 0.88);
  background:
    linear-gradient(90deg, rgba(6, 38, 26, 0.96), rgba(20, 85, 72, 0.9)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center 42% / cover;
  box-shadow: 0 10px 28px rgba(5, 28, 20, 0.16);
}

.register-header .public-brand {
  color: #ffffff;
}

.register-header .public-logo {
  flex-basis: 54px;
  width: 54px;
  height: 54px;
  border-color: rgba(255, 224, 163, 0.96);
}

.register-header .public-brand > span:last-child {
  color: #ffffff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
}

.register-home-link {
  min-height: 40px;
  display: inline-grid;
  place-items: center;
  padding: 0 18px;
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(5, 28, 20, 0.16);
}

.register-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}

.register-header .install-app-button {
  cursor: pointer;
}

.register-main {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 36px 0 56px;
}

.register-intro {
  display: grid;
  align-content: center;
  min-height: 420px;
  padding: 42px;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(10, 38, 31, 0.88), rgba(17, 58, 70, 0.62)),
    var(--topbar-bg-image, url("header-nepal-bg.svg")) center/cover;
  color: #ffffff;
}

.register-intro h1 {
  max-width: 760px;
  margin: 0;
  color: #ffffff;
  font-size: clamp(34px, 5vw, 64px);
}

.register-intro p:not(.eyebrow) {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 18px;
  line-height: 1.6;
}

.register-intro button,
.register-open-button {
  width: min(220px, 100%);
  min-height: 42px;
  display: inline-grid;
  place-items: center;
  margin-top: 16px;
  border-radius: 0;
  background: #f2c94c;
  color: #102a21;
  font-weight: 900;
  text-decoration: none;
}

.register-form-panel {
  margin-top: 24px;
  padding: 22px;
  scroll-margin-top: 96px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: var(--shadow);
}

.public-register-form {
  margin-top: 10px;
}

.register-preview-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.register-preview-grid article {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fbf9;
}

.register-preview-grid strong,
.register-preview-grid span {
  display: block;
  padding: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.register-preview-grid img {
  width: 100%;
  height: 120px;
  display: block;
  object-fit: cover;
  background: #ffffff;
}

.register-status {
  min-height: 24px;
  color: var(--muted);
  font-weight: 900;
}

.register-status.ok {
  color: var(--green);
}

.register-status.warning {
  color: #9a5b00;
}

@media (max-width: 900px) {
  .register-header {
    align-items: flex-start;
    flex-direction: column;
    padding: 12px 20px;
  }

  .register-intro,
  .register-form-panel {
    padding: 22px;
  }

  .register-preview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
