@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');

/* =======================================
   INREP SCHOLAR - UNIFIED DESIGN SYSTEM
   Greenly-inspired - Single :root block
   ======================================= */

:root {
  /* Greenly palette */
  --bg-dark:    #0a1f15;
  --bg-dark-2:  #112a1c;
  --bg-light:   #f5f7f2;
  --bg-white:   #ffffff;
  --primary:    #25c75a;
  --primary-dark: #0f7b3e;
  --primary-soft: #d4f5e0;
  --accent-green: #58de80;
  --text-dark:  #0a0a0a;
  --text-light: #f0f7f0;
  --text-muted-dark: #6b7b6e;
  --text-muted-light: #a8c4ae;
  --border-light: #e0e8e2;
  --border-dark: #1e3a28;
  --card-dark:  #0f2b1b;
  --card-dark-2: #162e20;
  --nav-text:   #1a1a1a;
  --cta-dark:   #111111;
  --cta-dark-hover: #222222;
  --inrep-radius: 10px;
  --inrep-button-radius: var(--inrep-radius);
  --radius:     var(--inrep-radius);
  --radius-lg:  var(--inrep-radius);
  --radius-pill: var(--inrep-radius);
  --shadow:     0 4px 24px rgba(10,31,21,.10);
  --shadow-lg:  0 16px 48px rgba(10,31,21,.16);
  --font-display: 'Sora', sans-serif;
  --font-body:  'DM Sans', sans-serif;
  /* Dashboard */
  --admin-bg:   #f5f7f2;
  --admin-canvas: #ffffff;
  --admin-border: #e0e8e2;
  --admin-sidebar-bg: #0a1f15;
  --admin-sidebar-width-collapsed: 56px;
  --admin-sidebar-width-expanded: 224px;
  /* Aliases - keep old code working */
  --bg:         #ffffff;
  --soft:       #f5f7f2;
  --soft-2:     #eef4ee;
  --card:       #ffffff;
  --border:     #e0e8e2;
  --border-muted: #edf2ee;
  --text:       #0a0a0a;
  --heading:    #0a0a0a;
  --muted:      #6b7b6e;
  --muted-2:    #7b8a7e;
  --green:      #25c75a;
  --green-dark: #0f7b3e;
  --green-hover: #0f7b3e;
  --green-soft: #dcfae6;
  --blue:       #0969da;
  --danger:     #cf222e;
  --admin-muted: #6b7b6e;
  --admin-subtle: #7b8a7e;
  --admin-heading: #0a0a0a;
}

/* -- Reset -- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-dark);
  background: var(--bg-white);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6 { font-family: var(--font-display); margin-top: 0; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--primary); }
img, svg, video { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; border: none; background: none; }
input, select, textarea {
  width: 100%; min-height: 44px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; background: #fff;
  color: var(--text-dark); padding: 10px 14px; outline: none;
}
textarea { min-height: 120px; resize: vertical; }
input:focus, select:focus, textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(29,185,84,.15);
}
label { font-weight: 650; font-size: 14px; color: var(--text-dark); display: block; margin-bottom: 6px; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border-light); vertical-align: top; }
th { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted-dark); background: var(--bg-light); }
tr:hover td { background: #f9fdf9; }

/* -- Accessibility -- */
.skip-link { position: fixed; left: 12px; top: -80px; z-index: 1000; background: var(--primary); color: #fff; padding: 10px 14px; border-radius: var(--inrep-radius, 10px) !important; font-weight: 700; }
.skip-link:focus { top: 12px; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }

/* -- Layout -- */
.container, .mkt-container { width: min(1200px, calc(100% - 48px)); margin-inline: auto; }
.container.narrow { max-width: 860px; }
.section { padding: 60px 0; }
.section--sm { padding: 48px 0; }
.grid-2 { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 24px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 24px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 24px; }

/* -- Typography helpers -- */
.section-eyebrow, .hero-eyebrow, .eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  width: max-content; max-width: 100%;
  padding: 4px 10px; border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid rgba(29,185,84,.3);
  background: rgba(29,185,84,.08);
  color: var(--primary-dark);
  font-size: 11px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
}
.section-h2, .section-title, .cards-section-title, .feature-showcase-h2 {
  font-family: var(--font-display);
  font-size: clamp(20px,2.4vw,34px); line-height: 1.1;
  letter-spacing: -.03em; color: var(--text-dark); margin: 0;
}
.section-sub, .hero-subtitle {
  color: var(--text-muted-dark); font-size: 15px; line-height: 1.65;
}
.text-green { color: var(--primary); }
.text-light { color: var(--text-light); }
.text-muted { color: var(--text-muted-dark); }
.bg-dark { background: var(--bg-dark); color: var(--text-light); }
.bg-dark-2 { background: var(--bg-dark-2); color: var(--text-light); }
.bg-light { background: var(--bg-light); }
.bg-white { background: var(--bg-white); }
.mkt-light, .section-soft { background: var(--bg-light); }

/* -- Buttons -- */
.btn, .btn-hero-primary, .btn-hero-secondary, .mkt-nav-signup, .btn-new-repo {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  min-height: 40px; padding: 10px 20px; border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid var(--border-light); background: #fff; color: var(--text-dark);
  font-family: var(--font-body); font-weight: 700; font-size: 14px; line-height: 1.2;
  text-decoration: none; transition: background .16s ease, border-color .16s ease, color .16s ease; cursor: pointer;
}
.btn:hover { background: var(--bg-light); }
.btn:active { transform: translateY(1px); }
.btn.primary, .btn-hero-primary, .btn-primary, .mkt-nav-signup, .btn-new-repo {
  background: var(--primary); border-color: var(--primary); color: #fff;
}
.btn.primary:hover, .btn-hero-primary:hover, .btn-primary:hover, .mkt-nav-signup:hover {
  background: var(--primary-dark); border-color: var(--primary-dark); color: #fff;
}
.btn.dark, .btn-dark { background: var(--cta-dark); border-color: var(--cta-dark); color: #fff; }
.btn.dark:hover, .btn-dark:hover { background: var(--cta-dark-hover); border-color: var(--cta-dark-hover); }
.btn-outline-green { color: var(--primary); border-color: var(--primary); background: transparent; }
.btn-outline-green:hover { background: var(--primary-soft); }
.btn-outline-white { color: #fff; border-color: rgba(255,255,255,.6); background: transparent; }
.btn-outline-white:hover { background: rgba(255,255,255,.1); }
.btn-hero-secondary { background: transparent; border-color: rgba(255,255,255,.5); color: #fff; }
.btn-hero-secondary:hover { background: rgba(255,255,255,.1); }
.btn.green, .btn.lime { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn.small, .btn-sm { min-height: 34px; padding: 7px 14px; font-size: 13px; }
.btn.tiny, .btn-xs { min-height: 28px; padding: 4px 10px; font-size: 12px; border-radius: var(--inrep-radius, 10px) !important; }
.btn-lg { min-height: 50px; padding: 13px 28px; font-size: 16px; }
.btn-link { color: var(--primary); font-weight: 700; background: none; border: none; padding: 0; cursor: pointer; }
.btn-link:hover { text-decoration: underline; }

/* -- Badges / pills -- */
.pill, .badge, .badge-private, .status-badge, .access-badge {
  display: inline-flex; align-items: center; width: max-content; gap: 6px;
  border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important;
  padding: 3px 9px; font-size: 12px; font-weight: 650;
  color: var(--text-muted-dark); background: #fff; text-transform: capitalize;
}
.badge-green, .pill.ok, .status-badge.ok, .status-badge.published, .status-badge.active,
.status-badge.approved, .access-badge.open, .record-pill {
  background: var(--primary-soft); color: var(--primary-dark); border-color: #a6f3b7;
}
.badge-dark { background: var(--bg-dark); color: var(--accent-green); border: 1px solid rgba(74,222,128,.3); }
.badge-white { background: #fff; color: var(--text-dark); border-color: var(--border-light); }
.pill.bad, .status-badge.bad, .status-badge.rejected, .status-badge.failed,
.status-badge.danger, .status-badge.suspended {
  background: #ffebe9; color: var(--danger); border-color: #ffcecb;
}
.pill.warn, .status-badge.warn, .status-badge.pending, .status-badge.submitted,
.status-badge.correction_requested {
  background: #fff8c5; color: #9a6700; border-color: #f0d98c;
}
.status-badge.view_only, .status-badge.restricted, .access-badge.restricted, .access-badge.view_only {
  background: #ddf4ff; color: var(--blue); border-color: #b6e3ff;
}

/* -- Cards -- */
.card, .admin-panel, .admin-profile-card, .dash-card, .metric-card {
  background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow);
}
.card-dark { background: var(--card-dark); border-color: var(--border-dark); color: var(--text-light); }

/* -- Alerts -- */
.alert, .admin-alert, .install-alert { border-radius: var(--inrep-radius, 10px) !important; padding: 12px 16px; border: 1px solid var(--border-light); margin: 0 0 16px; }
.alert.success, .alert-success, .admin-alert.success, .install-alert.success { background: var(--primary-soft); color: var(--primary-dark); border-color: #86efac; }
.alert.error, .alert-error, .admin-alert.error, .install-alert.error { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.alert.warn, .alert-warn { background: #fef3c7; color: #92400e; border-color: #fcd34d; }

/* -- Forms -- */
.form-group { margin-bottom: 16px; }
.form-grid { display: grid; gap: 16px; }
.form-grid-2, .public-form .form-grid-2 { grid-template-columns: repeat(2,minmax(0,1fr)); }
.span-full, .form-grid .span-full { grid-column: 1 / -1; }
.form-help, .mini-muted { color: var(--text-muted-dark); font-size: 13px; margin: 4px 0 0; }
.password-wrap { position: relative; }
.password-wrap input { padding-right: 70px; }
.password-wrap button, .password-toggle {
  position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
  background: var(--bg-light); border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; padding: 3px 8px; font-size: 13px; color: var(--text-muted-dark);
}
.public-form { display: grid; gap: 14px; }
.public-form .form-grid-2 { grid-template-columns: repeat(2,minmax(0,1fr)); }
.public-form textarea, .public-form button { grid-column: 1/-1; }
.progress-track { height: 10px; border-radius: var(--inrep-radius, 10px) !important; background: var(--border-light); overflow: hidden; }
.progress-fill { height: 100%; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary); }

/* -- Tables -- */
.admin-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.admin-table th, .admin-table td { padding: 12px 14px; border-bottom: 1px solid var(--border-light); text-align: left; vertical-align: top; }
.admin-table th { color: var(--text-muted-dark); font-weight: 650; background: var(--bg-light); }
.admin-table code { background: var(--bg-light); border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 2px 6px; }
.table-responsive { overflow-x: auto; }

/* =======================================
   ANNOUNCEMENT BAR
   ======================================= */
.announce-bar {
  position: relative; min-height: 40px; background: var(--bg-dark);
  display: flex; align-items: center; justify-content: center;
  gap: 12px; padding: 8px 54px 8px 16px;
  color: var(--text-muted-light); font-size: 13px;
  transition: transform .22s ease, opacity .22s ease, min-height .22s ease, padding .22s ease;
}
.announce-bar p { margin: 0; text-align: center; }
.announce-bar a { color: var(--accent-green); font-weight: 700; text-decoration: underline; }
.announce-bar-close {
  position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
  color: var(--text-muted-light); background: none; border: 0;
  font-size: 20px; line-height: 1; cursor: pointer;
}
.announce-bar--hidden { transform: translateY(-100%); opacity: 0; min-height: 0; padding-top: 0; padding-bottom: 0; overflow: hidden; }

/* =======================================
   PUBLIC NAVIGATION
   ======================================= */
.mkt-nav {
  position: sticky; top: 0; z-index: 200; width: 100%; height: 68px;
  display: grid; grid-template-columns: auto minmax(0,1fr) auto auto;
  align-items: center; gap: 18px; padding: 0 48px;
  background: rgba(255,255,255,.95); border-bottom: 1px solid var(--border-light);
  backdrop-filter: blur(14px);
}
.mkt-nav.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,.08); }
.mkt-nav-logo {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-weight: 700; font-size: 18px;
  color: var(--text-dark); letter-spacing: -.02em; white-space: nowrap;
}
.mkt-nav-logo .inrep-mark {
  width: 34px; height: 34px; border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-dark);
  color: #fff; display: grid; place-items: center; font-weight: 700;
}
/* Institution initials badge — shown when institution has no logo */
.tenant-initials-mark {
  width: 34px; height: 34px; border-radius: var(--inrep-radius, 10px) !important;
  background: var(--tenant-primary, var(--bg-dark));
  color: #fff; display: grid; place-items: center;
  font-size: 12px; font-weight: 800; flex-shrink: 0; line-height: 1;
}
/* Institution-branded "Create account" CTA uses institution primary colour */
.tenant-nav-signup {
  background: var(--tenant-primary, #1db954) !important;
  border-color: var(--tenant-primary, #1db954) !important;
  color: #fff !important;
}
.tenant-nav-signup:hover {
  filter: brightness(0.88);
}
.mkt-nav-items { display: flex; align-items: center; justify-content: center; gap: 4px; min-width: 0; }
.mkt-nav-item, .mkt-nav-menu-btn, .mkt-nav-signin {
  font-size: 14px; font-weight: 500; color: var(--nav-text);
  padding: 6px 12px; border-radius: var(--inrep-radius, 10px) !important; background: transparent; border: 0;
  display: inline-flex; align-items: center; gap: 5px; cursor: pointer; white-space: nowrap;
}
.mkt-nav-item:hover, .mkt-nav-menu-btn:hover { background: var(--bg-light); color: var(--text-dark); }
.mkt-nav-item[aria-current="page"], .mkt-nav-item.active { color: var(--primary); }
.mkt-nav-group { position: relative; }
.mkt-nav-group.open > .mkt-nav-menu-btn { background: var(--bg-light); }
.mkt-nav-group.open .mkt-nav-menu-btn svg { transform: rotate(180deg); }
.mkt-dropdown {
  position: absolute; top: calc(100% + 8px); left: 0;
  min-width: 260px; display: none; gap: 4px; padding: 8px;
  background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow-lg); z-index: 300;
}
.mkt-nav-group.open > .mkt-dropdown { display: grid; }
.mkt-dropdown a {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 10px 12px; border-radius: var(--inrep-radius, 10px) !important; color: var(--text-dark);
}
.mkt-dropdown a:hover { background: var(--bg-light); color: var(--text-dark); }
.mkt-dropdown svg { width: 18px; height: 18px; color: var(--primary); margin-top: 2px; flex: none; }
.mkt-dropdown small { color: var(--text-muted-dark); display: block; margin-top: 2px; }
.mkt-nav-search {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-light); border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; padding: 6px 12px; width: min(220px,18vw);
}
.mkt-nav-search input { min-height: auto; border: 0; background: transparent; box-shadow: none; font-size: 13px; padding: 0; }
.mkt-nav-search-shortcut, .dash-nav-search-kbd {
  border: 1px solid var(--border-light); background: #fff;
  color: var(--text-muted-dark); border-radius: var(--inrep-radius, 10px) !important; padding: 1px 5px; font-size: 11px;
}
.mkt-nav-actions { display: flex; align-items: center; gap: 10px; }
.mkt-nav-toggle {
  display: none; width: 40px; height: 40px;
  border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important;
  background: #fff; color: var(--bg-dark);
  align-items: center; justify-content: center;
}
/* Mobile nav */
.mkt-mobile-overlay {
  position: fixed; inset: 0; z-index: 190;
  background: rgba(10,31,21,.5); opacity: 0; pointer-events: none; transition: opacity .2s;
}
body.drawer-open .mkt-mobile-overlay { opacity: 1; pointer-events: auto; }
body.drawer-open, body.public-nav-open { overflow: hidden; }
.mkt-mobile-drawer {
  position: fixed; right: 0; top: 0; height: 100vh;
  width: min(320px,88vw); background: #fff;
  border-left: 1px solid var(--border-light);
  transform: translateX(100%); transition: transform .24s ease;
  z-index: 260; padding: 18px; display: grid; grid-template-rows: auto auto 1fr; gap: 16px;
}
body.drawer-open .mkt-mobile-drawer, body.public-nav-open .mkt-mobile-drawer { transform: none; }
.mkt-mobile-drawer-head { display: flex; justify-content: space-between; align-items: center; }
.mkt-mobile-close {
  width: 40px; height: 40px; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; background: #fff; display: grid; place-items: center;
}
.mkt-mobile-links { display: grid; align-content: start; gap: 6px; overflow-y: auto; }
.mkt-mobile-links a { padding: 12px; border-radius: var(--inrep-radius, 10px) !important; font-weight: 600; color: var(--text-dark); display: block; }
.mkt-mobile-links a:hover { background: var(--bg-light); }

/* =======================================
   AUTH PAGES (guest layout)
   ======================================= */
.auth-body {
  min-height: 100dvh; background: var(--bg-dark);
  display: grid; place-items: center; padding: 24px;
  position: relative; overflow: hidden;
  font-family: var(--font-body);
}
.auth-body::before {
  content: ''; position: absolute; top: -20%; left: -10%;
  width: 60%; height: 80%;
  background: radial-gradient(ellipse, rgba(29,185,84,.12) 0%, transparent 70%);
  pointer-events: none;
}
.auth-body::after {
  content: ''; position: absolute; bottom: -20%; right: -10%;
  width: 50%; height: 70%;
  background: radial-gradient(ellipse, rgba(74,222,128,.08) 0%, transparent 70%);
  pointer-events: none;
}
.auth-wrapper {
  position: relative; width: 100%; display: grid; place-items: center;
  min-height: 100dvh;
}
.auth-deco { position: fixed; pointer-events: none; user-select: none; z-index: 1; }
.auth-deco--left { left: 5%; top: 50%; transform: translateY(-50%) rotate(-8deg); width: 260px; opacity: .9; }
.auth-deco--right { right: 5%; top: 50%; transform: translateY(-50%) rotate(10deg); width: 230px; opacity: .9; }
.auth-center, .auth-card--inrep, .auth-wrapper .auth-card {
  position: relative; z-index: 10;
  width: min(440px, calc(100vw - 48px));
  background: #fff; border-radius: var(--inrep-radius, 10px) !important; padding: 40px;
  box-shadow: 0 32px 80px rgba(0,0,0,.4); border: 0;
}
.auth-logo {
  display: flex; align-items: center; gap: 10px; margin-bottom: 28px;
  font-family: var(--font-display); font-size: 22px; font-weight: 700; color: var(--text-dark);
}
.auth-logo .inrep-mark {
  width: 38px; height: 38px; border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-dark);
  color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 14px; flex: none;
}
.auth-title { font-family: var(--font-display); font-size: 26px; font-weight: 700; color: var(--text-dark); margin: 0 0 24px; }
.auth-field, .auth-form .form-group { margin-bottom: 16px; }
.auth-forgot { display: block; color: var(--primary); font-weight: 600; font-size: 14px; margin-bottom: 16px; }
.auth-submit, .auth-form button[type="submit"] { width: 100%; }
.auth-links { text-align: center; font-size: 13px; color: var(--text-muted-dark); margin-top: 20px; }
.auth-links a { color: var(--primary); font-weight: 600; }
.auth-help { text-align: center; font-size: 13px; color: var(--text-muted-dark); margin-top: 16px; }
.auth-help a { color: var(--primary); }
.auth-subtitle { color: var(--text-muted-dark); font-size: 15px; text-align: center; margin: 0 0 18px; }
.small-auth-card { padding: 14px; text-align: center; margin-top: 14px; }
.sso-account-type {
  border: 0;
  padding: 0;
  margin: 0 0 16px;
  display: grid;
  gap: 10px;
}
.sso-account-type legend {
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--text-dark);
}
.sso-account-option {
  display: grid;
  grid-template-columns: 20px 1fr;
  align-items: start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  cursor: pointer;
  background: #fff;
  margin: 0;
}
.sso-account-option:has(input:checked) {
  border-color: var(--primary);
  background: #f2fbf5;
}
.sso-account-option input[type="radio"] {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  margin: 2px 0 0;
  padding: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: none !important;
  accent-color: var(--primary);
}
.sso-account-option strong,
.sso-account-option small {
  display: block;
}
.sso-account-option small {
  margin-top: 4px;
  color: var(--text-muted-dark);
  line-height: 1.35;
}
/* Register split panel */
.register-center { width: min(960px, calc(100% - 48px)); margin: 0 auto; }
.signup-form-grid { display: grid; grid-template-columns: 380px 1fr; min-height: calc(100vh - 68px); align-items: stretch; }
.signup-intro-card {
  background: var(--bg-dark); color: var(--text-light);
  padding: 48px 40px; display: flex; flex-direction: column; gap: 28px;
  border-radius: var(--inrep-radius, 10px) !important;
}
.signup-intro-card h2 { font-family: var(--font-display); font-size: 28px; color: #fff; margin: 0; }
.signup-intro-card p { color: var(--text-muted-light); font-size: 15px; }
.signup-intro-card .auth-logo { color: #fff; margin-bottom: 0; }

/* =======================================
   HERO - DARK (home page)
   ======================================= */
.mkt-hero.mkt-hero--dark, .mkt-hero-rebuilt.mkt-hero--dark {
  position: relative; min-height: 90vh; display: flex; align-items: center;
  padding: 80px 0 100px;
  background: radial-gradient(ellipse 80% 60% at 30% 40%, #1a4a2e 0%, #0a1f15 70%);
  color: var(--text-light); overflow: hidden;
}
.mkt-hero.mkt-hero--dark::after {
  content: ''; position: absolute; inset: 0; opacity: .04;
  background-image: radial-gradient(circle at 1px 1px, #fff 1px, transparent 0);
  background-size: 24px 24px; pointer-events: none;
}
.mkt-hero-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
  width: min(1200px, calc(100% - 48px)); margin: auto;
}
.mkt-hero--dark .hero-eyebrow {
  color: var(--accent-green); background: rgba(22,46,32,.9); border-color: rgba(74,222,128,.3);
}
.hero-h1, .mkt-hero-h1 {
  font-family: var(--font-display); font-size: clamp(26px,3.2vw,44px);
  font-weight: 700; line-height: 1.08; letter-spacing: -.03em; margin: 0 0 16px;
}
.mkt-hero--dark .hero-h1 { color: var(--text-light); }
.mkt-hero--dark .hero-subtitle { color: var(--text-muted-light); max-width: 520px; }
.hero-ctas, .mkt-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin: 0 0 28px; }
.hero-trust-row, .mkt-hero-trust {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  color: var(--text-muted-light); font-size: 12px;
}
.hero-trust-row span:not(:last-child)::after { content: '-'; margin-left: 12px; color: rgba(255,255,255,.45); }
/* Hero product mockup */
.mkt-hero-product {
  background: var(--card-dark); border: 1px solid var(--border-dark);
  border-radius: var(--inrep-radius, 10px) !important; padding: 20px;
  box-shadow: 0 32px 80px rgba(0,0,0,.5);
  transform: perspective(1200px) rotateY(-8deg) rotateX(3deg);
  transition: transform .4s ease;
}
.mkt-hero-product:hover { transform: perspective(1200px) rotateY(-4deg) rotateX(1deg); }
.product-chrome { display: flex; align-items: center; gap: 6px; padding-bottom: 14px; border-bottom: 1px solid var(--border-dark); margin-bottom: 14px; }
.chrome-dot { width: 10px; height: 10px; border-radius: var(--inrep-radius, 10px) !important; flex-shrink: 0; }
.chrome-title { font-size: 11px; color: rgba(255,255,255,.3); margin-left: 8px; font-family: 'Courier New', monospace; }
.product-search {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border-dark);
  border-radius: var(--inrep-radius, 10px) !important; padding: 8px 12px; margin-bottom: 12px;
  font-size: 12px; color: rgba(255,255,255,.35);
}
.product-search kbd { margin-left: auto; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: var(--inrep-radius, 10px) !important; padding: 1px 5px; font-size: 11px; }
.product-record { padding: 10px; border-radius: var(--inrep-radius, 10px) !important; margin-bottom: 6px; border: 1px solid transparent; background: transparent; }
.product-record.active { background: rgba(29,185,84,.08); border-color: rgba(29,185,84,.2); }
.product-record strong { display: block; font-size: 12px; color: rgba(255,255,255,.85); font-weight: 600; margin: 4px 0 3px; line-height: 1.4; }
.product-record span, .product-record small { display: block; font-size: 11px; color: rgba(255,255,255,.35); }
.product-badge { display: inline-flex; align-items: center; padding: 2px 7px; border-radius: var(--inrep-radius, 10px) !important; font-size: 10px; font-weight: 600; }
.product-badge.open { background: rgba(29,185,84,.2); color: #4ade80; }
.product-badge.restricted { background: rgba(59,130,246,.2); color: #93c5fd; }
.product-badge.meta { background: rgba(245,158,11,.15); color: #fcd34d; }
.product-metrics { display: flex; border-top: 1px solid var(--border-dark); margin-top: 12px; padding-top: 12px; }
.product-metrics > div { flex: 1; text-align: center; padding: 0 8px; border-right: 1px solid var(--border-dark); }
.product-metrics > div:last-child { border-right: none; }
.product-metrics b { display: block; font-family: var(--font-display); font-size: 18px; font-weight: 700; color: #fff; }
.product-metrics span { font-size: 10px; color: rgba(255,255,255,.35); }
/* Old mockup fallback */
.product-window-top { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.3); font-size: 12px; margin-bottom: 14px; }
.product-window-top span { width: 8px; height: 8px; border-radius: var(--inrep-radius, 10px) !important; background: var(--border-dark); }
.product-search-line { display: flex; justify-content: space-between; align-items: center; border: 1px solid var(--border-dark); border-radius: var(--inrep-radius, 10px) !important; padding: 10px 12px; color: rgba(255,255,255,.3); background: rgba(255,255,255,.06); margin-bottom: 12px; }

/* =======================================
   PAGE HERO - inner pages (light)
   ======================================= */
.page-hero, .docs-hero {
  padding: 60px 0 48px; position: relative; overflow: hidden;
  text-align: center; background: #fff;
}
.page-hero::after, .docs-hero::after {
  content: ''; position: absolute; right: -5%; top: -20%;
  width: 45%; height: 140%;
  background: radial-gradient(ellipse at center, rgba(29,185,84,.10) 0%, rgba(29,185,84,.04) 40%, transparent 70%);
  pointer-events: none; z-index: 0;
}
.page-hero > *, .docs-hero > * { position: relative; z-index: 1; }
.page-hero .hero-eyebrow { margin-bottom: 14px; }
.page-hero .hero-h1, .page-hero-h1 {
  font-family: var(--font-display); font-size: clamp(28px,3vw,40px); font-weight: 700;
  color: var(--text-dark); letter-spacing: -.025em; line-height: 1.1;
  margin: 0 auto 14px; max-width: 720px;
}
.page-hero .hero-subtitle, .page-hero-sub {
  font-size: 17px; color: var(--text-muted-dark); max-width: 560px;
  line-height: 1.65; margin: 0 auto 28px;
}

/* =======================================
   STATS STRIP
   ======================================= */
.stats-section { padding: 40px 0; background: var(--bg-light); border-top: 1px solid var(--border-light); }
.stats-section.stats-dark { background: var(--bg-dark-2); color: #fff; border-top: 0; }
.stats-grid {
  display: grid; grid-template-columns: repeat(4,minmax(0,1fr));
  max-width: 1000px; margin: auto;
}
.stat-item { padding: 24px; text-align: center; border-right: 1px solid var(--border-light); }
.stats-dark .stat-item { border-right-color: var(--border-dark); }
.stat-item:last-child { border-right: 0; }
.stat-number, .stat-value { font-family: var(--font-display); font-size: 42px; font-weight: 700; color: inherit; }
.stat-label { font-size: 13px; color: var(--text-muted-dark); }
.stats-dark .stat-label { color: var(--text-muted-light); }

/* =======================================
   SECTIONS - cards / workflow / audience
   ======================================= */
.cards-section, .workflow-section, .audience-section,
.search-preview-section, .testimonial-section, .pricing-section, .faq-section { padding: 60px 0; }
.cards-section.mkt-light, .workflow-section, .pricing-section { background: var(--bg-light); }
.section-heading, .cards-section-header, .cards-section .section-heading {
  text-align: center; max-width: 680px; margin: 0 auto 48px;
}
.section-heading .hero-eyebrow { margin-inline: auto; }

/* Feature cards */
.cards-grid, .cards-grid-3, .cards-grid-3x2, .projects-public-grid {
  display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 20px;
  width: min(1200px, calc(100% - 48px)); margin: auto;
}
.cards-grid:not(.cards-grid-3):not(.cards-grid-3x2) { grid-template-columns: repeat(4,minmax(0,1fr)); }
.feature-card, .project-public-card, .docs-card, .pricing-card {
  background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; padding: 24px;
  display: flex; flex-direction: column; gap: 12px;
  transition: box-shadow .2s, transform .2s; color: var(--text-dark);
}
.feature-card:hover, .project-public-card:hover, .docs-card:hover {
  box-shadow: var(--shadow-lg); transform: translateY(-3px);
}
.feature-card-icon {
  width: 40px; height: 40px; border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-dark); display: grid; place-items: center;
  color: var(--accent-green); flex-shrink: 0;
}
.feature-card-title { font-family: var(--font-display); font-size: 16px; font-weight: 650; color: var(--text-dark); margin: 0; }
.feature-card-desc { font-size: 14px; color: var(--text-muted-dark); margin: 0; flex: 1; }
.feature-card-link, .feature-showcase-link {
  font-size: 13px; font-weight: 700; color: var(--primary);
  display: inline-flex; align-items: center; gap: 4px; margin-top: auto;
}
.feature-card-link:hover { gap: 8px; }

/* Workflow tabs */
.workflow-grid {
  width: min(1200px, calc(100% - 48px)); margin: auto;
  display: grid; grid-template-columns: 280px 1fr; gap: 40px; align-items: start;
}
.workflow-tabs { display: flex; flex-direction: column; gap: 4px; }
.workflow-tab {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: var(--inrep-radius, 10px) !important; cursor: pointer;
  border: none; border-left: 3px solid transparent;
  background: transparent; text-align: left; width: 100%;
  transition: all .15s ease; font-family: var(--font-body); color: inherit;
}
.workflow-tab:hover { background: rgba(29,185,84,.06); }
.workflow-tab.active { background: #fff; border-left-color: var(--primary); box-shadow: var(--shadow); }
.workflow-tab-num, .workflow-tab span:first-child {
  font-family: var(--font-display); font-size: 22px; font-weight: 700;
  color: var(--border-light); line-height: 1; min-width: 32px; transition: color .15s;
}
.workflow-tab.active .workflow-tab-num, .workflow-tab.active span:first-child { color: var(--primary); }
.workflow-tab-label, .workflow-tab span:not(:first-child) { font-size: 14px; font-weight: 600; color: var(--text-muted-dark); }
.workflow-tab.active .workflow-tab-label, .workflow-tab.active span:not(:first-child) { color: var(--text-dark); }
.workflow-panels { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 36px; box-shadow: var(--shadow); }
.workflow-panel { display: none; }
.workflow-panel.active { display: block; }
.workflow-panel h3 { font-family: var(--font-display); margin: 0 0 12px; font-size: 26px; color: var(--text-dark); }
.workflow-panel p { color: var(--text-muted-dark); font-size: 16px; }

/* Audience cards */
.audience-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 20px; width: min(1200px,calc(100% - 48px)); margin: auto; }
.audience-card { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 20px; display: grid; gap: 8px; color: var(--text-dark); }
.audience-card:hover { border-color: var(--primary); box-shadow: var(--shadow); }
.mini-dot { width: 8px; height: 8px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary); }

/* Testimonials */
.testimonial-section, .feature-showcase, .audience-section.dark { background: var(--bg-dark); color: var(--text-light); padding: 60px 0; }
.testimonial-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 20px; width: min(1200px,calc(100% - 48px)); margin: auto; }
.testimonial-card { background: var(--card-dark); border: 1px solid var(--border-dark); border-radius: var(--inrep-radius, 10px) !important; padding: 24px; }
.testimonial-card blockquote { color: var(--text-muted-light); font-style: italic; margin: 0 0 16px; line-height: 1.7; }

/* Feature showcase */
.feature-showcase-grid {
  width: min(1200px,calc(100% - 48px)); margin: auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
.feature-showcase h2, .feature-showcase .section-title { color: #fff; }
.feature-showcase p { color: var(--text-muted-light); }

/* Search preview */
.search-preview-section {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
  width: min(1200px,calc(100% - 48px)); margin: auto;
}
.search-preview-card { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 24px; box-shadow: var(--shadow); }
.search-preview-bar { display: flex; justify-content: space-between; align-items: center; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 10px 12px; color: var(--text-muted-dark); background: var(--bg-light); margin-bottom: 12px; }
.search-preview-row { padding: 12px 0; border-bottom: 1px solid var(--border-light); }
.search-preview-row:last-child { border-bottom: 0; }
.search-preview-row b { display: block; color: var(--text-dark); }
.search-preview-row span { font-size: 13px; color: var(--text-muted-dark); }

/* Final CTA section */
.final-cta { padding: 60px 0; text-align: center; background: var(--bg-dark); }
.final-cta h2 { font-family: var(--font-display); max-width: 640px; margin: 0 auto 14px; color: #fff; font-size: clamp(20px,2.4vw,34px); line-height: 1.1; letter-spacing: -.03em; }
.final-cta p { max-width: 480px; margin: 0 auto 28px; color: var(--text-muted-light); font-size: 15px; }
.final-cta .hero-ctas { justify-content: center; }

/* Checklist (dark section widget) */
.checklist-card { background: #fff; border-radius: var(--inrep-radius, 10px) !important; padding: 24px 28px; display: flex; flex-direction: column; gap: 14px; box-shadow: 0 8px 32px rgba(0,0,0,.2); }
.checklist-item { display: flex; align-items: center; gap: 12px; font-size: 14px; color: var(--text-dark); font-weight: 500; }
.checklist-dot { width: 20px; height: 20px; border-radius: var(--inrep-radius, 10px) !important; border: 2px solid var(--primary); background: var(--primary-soft); flex-shrink: 0; display: grid; place-items: center; }
.checklist-dot::after { content: ''; width: 8px; height: 8px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary); }

/* =======================================
   PUBLIC PAGE-SPECIFIC
   ======================================= */
/* Status */
.status-board { width: min(820px,calc(100% - 48px)); margin: 0 auto; display: grid; gap: 12px; }
.status-row { display: flex; gap: 14px; padding: 16px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow); }
.status-dot { width: 12px; height: 12px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary); margin-top: 5px; flex: 0 0 auto; }
.status-row p { margin: 4px 0 0; color: var(--text-muted-dark); }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; width: min(1100px,calc(100% - 48px)); margin: auto; }
.contact-card { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 32px; box-shadow: var(--shadow); }
.contact-support-grid { display: grid; gap: 12px; margin-top: 20px; }
.contact-support-grid div { padding: 16px; border-bottom: 1px solid var(--border-light); }
.contact-support-grid span { display: block; color: var(--text-muted-dark); margin-top: 4px; font-size: 14px; }

/* Solutions */
.solution-list { width: min(1080px,calc(100% - 48px)); margin: 0 auto; display: grid; gap: 20px; }
.solution-row { display: grid; grid-template-columns: minmax(0,1fr) 340px; gap: 24px; padding: 28px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow); }
.solution-row h2 { margin: 8px 0; color: var(--text-dark); font-size: 26px; font-family: var(--font-display); }
.solution-row p { color: var(--text-muted-dark); }
.solution-row aside { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light); padding: 18px; display: grid; gap: 10px; }

/* Resources */
.resource-grid { width: min(1200px,calc(100% - 48px)); margin: auto; display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 20px; }
.resource-card { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 24px; box-shadow: var(--shadow); }
.resource-card h2 { font-family: var(--font-display); color: var(--text-dark); margin: 0 0 10px; font-size: 18px; }
.resource-card ul { padding-left: 18px; color: var(--text-muted-dark); margin: 0; }

/* Docs */
.docs-search { width: min(480px,100%); margin: 24px auto 0; display: flex; gap: 8px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 8px; }
.docs-search input { border: 0; box-shadow: none; }
.docs-grid { width: min(1200px,calc(100% - 48px)); margin: auto; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 20px; }
.docs-card { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 24px; box-shadow: var(--shadow); }
.docs-card h2 { font-family: var(--font-display); color: var(--text-dark); margin: 0 0 12px; }
.docs-card a { display: block; color: var(--primary); padding: 5px 0; font-size: 14px; }
.help-panel { width: min(1100px,calc(100% - 48px)); margin: 0 auto 64px; padding: 24px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; display: flex; align-items: center; justify-content: space-between; gap: 18px; }

/* Implementation */
.timeline-rebuilt { width: min(900px,calc(100% - 48px)); margin: 0 auto; }
.timeline-item { display: grid; grid-template-columns: 64px 1fr; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--border-light); }
.timeline-item:last-child { border-bottom: 0; }
.timeline-num { width: 52px; height: 52px; border-radius: var(--inrep-radius, 10px) !important; background: var(--text-dark); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; }

/* Projects / Repository browser */
.repository-browser { padding: 60px 0; }
.repository-filter-card { width: min(1200px,calc(100% - 48px)); margin: 0 auto 24px; padding: 20px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow); }
.filter-main { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr auto; gap: 12px; align-items: end; }
.filter-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.repository-results-head { width: min(1200px,calc(100% - 48px)); margin: 0 auto 20px; display: flex; justify-content: space-between; gap: 16px; color: var(--text-muted-dark); }
.repository-results-head strong { color: var(--text-dark); font-size: 16px; }
.repository-grid { width: min(1200px,calc(100% - 48px)); margin: auto; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 20px; }
.project-public-card h3 { margin: 0; color: var(--text-dark); font-size: 16px; line-height: 1.3; }
.project-public-card p, .project-public-card small { color: var(--text-muted-dark); font-size: 13px; }
.project-meta-list { display: flex; flex-wrap: wrap; gap: 8px; }
.project-meta-list span { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 3px 8px; color: var(--text-muted-dark); font-size: 12px; }

/* Project detail */
.project-detail-rebuilt { width: min(1180px,calc(100% - 48px)); margin: 0 auto; padding: 60px 0; display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 28px; }
.project-detail-main, .project-detail-side { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 28px; box-shadow: var(--shadow); }
.project-breadcrumb, .project-meta-strip { display: flex; flex-wrap: wrap; gap: 8px; color: var(--text-muted-dark); font-size: 13px; }
.project-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border-light); }
.metadata-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.metadata-grid div { background: var(--bg-light); border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 12px; }
.metadata-grid dt { color: var(--text-muted-dark); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.metadata-grid dd { margin: 4px 0 0; color: var(--text-dark); }

/* FAQ */
.faq-list { width: min(860px,calc(100% - 48px)); margin: 0 auto; display: grid; gap: 10px; }
.faq-list details { background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 18px; }
.faq-list summary { cursor: pointer; font-weight: 650; color: var(--text-dark); font-size: 15px; }
.faq-list p { color: var(--text-muted-dark); margin: 12px 0 0; }

/* Pricing */
.pricing-grid { width: min(1200px,calc(100% - 48px)); margin: 0 auto; display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 18px; }

/* Viewer */
.viewer { background: #0d1117; min-height: 100vh; color: #e6edf3; padding: 16px; }
.viewer-toolbar { position: sticky; top: 0; z-index: 5; display: flex; align-items: center; justify-content: space-between; gap: 12px; background: #161b22; border: 1px solid #30363d; border-radius: var(--inrep-radius, 10px) !important; padding: 12px; margin-bottom: 16px; }
.viewer-page { margin: 0 0 18px; background: #fff; border-radius: var(--inrep-radius, 10px) !important; overflow: hidden; }
.viewer-page img { width: 100%; height: auto; display: block; }

/* =======================================
   FOOTER
   ======================================= */
.mkt-footer, .mkt-footer.mkt-footer--dark {
  background: #0a0a0a; color: #888;
  border: 0; border-radius: var(--inrep-radius, 10px) !important;
}
.mkt-footer-inner {
  width: min(1200px,calc(100% - 48px)); margin: auto;
  display: grid; grid-template-columns: 280px repeat(4,minmax(0,1fr));
  gap: 40px; padding: 60px 0 32px;
}
.mkt-footer-logo { display: flex; align-items: center; gap: 10px; color: #fff; font-family: var(--font-display); font-size: 22px; font-weight: 700; margin-bottom: 12px; }
.mkt-footer-logo .inrep-mark { background: var(--primary); }
.mkt-footer-tagline { color: #666; font-size: 14px; line-height: 1.6; max-width: 240px; margin-bottom: 20px; }
.mkt-footer h3, .mkt-footer-col-title { color: #555; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 12px; font-weight: 700; }
.mkt-footer-col-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.mkt-footer-col-list a, .mkt-footer a { color: #888; font-size: 14px; }
.mkt-footer-col-list a:hover, .mkt-footer a:hover { color: #fff; }
.mkt-footer-newsletter { display: flex; flex-direction: column; gap: 8px; }
.mkt-footer-newsletter input {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--inrep-radius, 10px) !important; color: #fff; min-height: 40px; padding: 8px 14px;
  font-size: 14px; width: 100%;
}
.mkt-footer-newsletter input::placeholder { color: rgba(255,255,255,.35); }
.mkt-footer-newsletter input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(29,185,84,.2); outline: none; }
.mkt-footer-subscribe-btn, .mkt-footer-newsletter .btn {
  width: 100%; background: var(--primary); color: #fff; border: none;
  min-height: 40px; border-radius: var(--inrep-radius, 10px) !important; font-weight: 650; font-size: 14px;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.mkt-footer-subscribe-btn:hover, .mkt-footer-newsletter .btn:hover { background: var(--primary-dark); }
.mkt-footer-bottom {
  width: min(1200px,calc(100% - 48px)); margin: 32px auto 0;
  padding-top: 24px; border-top: 1px solid #1a1a1a;
  display: flex; justify-content: space-between; align-items: center;
  gap: 18px; font-size: 12px; color: #555;
}
.mkt-footer-bottom a { color: #666; }
.mkt-footer-bottom a:hover { color: #fff; }
/* Subtle "Powered by Inrep Scholar" attribution in tenant footer */
.mkt-footer-powered-link {
  opacity: 0.45;
  font-size: 11px;
  color: inherit !important;
  text-decoration: none;
  transition: opacity .15s;
}
.mkt-footer-powered-link:hover { opacity: 0.85; }

/* =======================================
   DASHBOARD / ADMIN LAYOUT
   ======================================= */
body.admin-fullscreen { height: 100dvh; overflow: hidden; background: var(--admin-bg); }
.admin-shell {
  display: grid;
  grid-template-columns: var(--admin-sidebar-width-collapsed) minmax(0,1fr);
  min-height: 100vh; background: var(--admin-bg); gap: 0; transition: grid-template-columns .2s ease;
}
body:not(.admin-sidebar-collapsed) .admin-shell { grid-template-columns: var(--admin-sidebar-width-expanded) minmax(0,1fr); }

/* Sidebar */
.admin-sidebar {
  position: sticky; top: 0; height: 100dvh; overflow-y: auto; overflow-x: hidden;
  background: var(--admin-sidebar-bg); border-right: 1px solid var(--border-dark);
  padding: 12px 8px; z-index: 80;
}
.admin-sidebar-header {
  display: grid; grid-template-columns: 40px; justify-content: center;
  gap: 8px; padding: 0 0 10px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 8px;
}
body:not(.admin-sidebar-collapsed) .admin-sidebar-header { grid-template-columns: 1fr 36px; justify-content: stretch; }
.admin-sidebar-brand { display: flex; align-items: center; gap: 10px; color: #fff; font-family: var(--font-display); font-weight: 700; }
.admin-sidebar-brand .inrep-mark {
  width: 40px; height: 40px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary);
  color: #fff; display: grid; place-items: center; font-weight: 700; flex: none;
}
body.admin-sidebar-collapsed .admin-sidebar-brand span:not(.inrep-mark) { display: none; }
.admin-sidebar-close, .admin-sidebar-collapse-toggle {
  width: 36px; height: 36px; border: 0; border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.08); color: var(--text-muted-light);
  display: grid; place-items: center;
}
.admin-sidebar-close:hover, .admin-sidebar-collapse-toggle:hover { background: rgba(255,255,255,.12); color: #fff; }
.admin-sidebar-section { padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.admin-sidebar-section:last-child { border-bottom: 0; }
.admin-sidebar-label {
  display: none; color: rgba(255,255,255,.28); font-size: 10px;
  text-transform: uppercase; letter-spacing: .08em; padding: 10px 8px 4px;
}
body:not(.admin-sidebar-collapsed) .admin-sidebar-label { display: block; }
.admin-sidebar-link {
  width: 40px; height: 40px; border-radius: var(--inrep-radius, 10px) !important;
  display: flex; align-items: center; justify-content: center;
  gap: 10px; padding: 0; background: transparent; color: var(--text-muted-light);
  border: 0; cursor: pointer; text-decoration: none;
}
body:not(.admin-sidebar-collapsed) .admin-sidebar-link { width: 100%; justify-content: flex-start; padding: 10px 12px; }
.admin-sidebar-link svg { width: 16px; height: 16px; flex: none; }
.admin-sidebar-link span { display: none; font-size: 13px; font-weight: 500; white-space: nowrap; }
body:not(.admin-sidebar-collapsed) .admin-sidebar-link span { display: inline; }
.admin-sidebar-link:hover { background: rgba(255,255,255,.08); color: #fff; }
.admin-sidebar-link.active { background: rgba(29,185,84,.16); color: var(--accent-green); }
/* Keep collapsed behavior for sidebar sub-items */
.admin-sidebar-recent, .admin-sidebar-pinned { display: none; }
body:not(.admin-sidebar-collapsed) .admin-sidebar-recent,
body:not(.admin-sidebar-collapsed) .admin-sidebar-pinned { display: block; }

/* Topbar */
.admin-topbar {
  height: 64px; position: sticky; top: 0; z-index: 80;
  display: flex; align-items: center; gap: 12px; padding: 0 20px;
  background: #fff; border-bottom: 1px solid var(--border-light);
}
.admin-topbar-menu { width: 38px; height: 38px; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: #fff; display: none; align-items: center; justify-content: center; }
.admin-topbar-title { color: var(--text-dark); font-family: var(--font-display); font-weight: 700; min-width: max-content; font-size: 16px; }
.admin-search {
  width: min(380px,30vw); min-width: 180px; display: flex; align-items: center; gap: 8px;
  margin-left: 12px; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light); padding: 0 10px; color: var(--text-muted-dark);
}
.admin-search input { min-height: 36px; padding: 0; border: 0; background: transparent; box-shadow: none; }
.admin-topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.admin-icon-btn {
  width: 38px; height: 38px; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; background: #fff; color: var(--text-muted-dark);
  display: inline-flex; align-items: center; justify-content: center; position: relative;
}
.admin-icon-btn:hover { background: var(--bg-light); color: var(--text-dark); }
.admin-notif-badge {
  position: absolute; top: 6px; right: 6px; width: 8px; height: 8px;
  border-radius: var(--inrep-radius, 10px) !important; background: #ef4444; border: 2px solid #fff;
}
.admin-avatar {
  width: 38px; height: 38px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary);
  color: #fff; font-weight: 700; font-size: 15px; display: grid; place-items: center;
}
.admin-profile-menu { position: relative; display: flex; align-items: center; }
.admin-profile-trigger { padding: 0; border: 0; background: transparent; border-radius: var(--inrep-radius, 10px) !important; cursor: pointer; }
.admin-profile-popover {
  position: absolute; top: calc(100% + 10px); right: 0;
  width: min(300px,calc(100vw - 24px)); padding: 16px;
  border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important;
  background: #fff; box-shadow: 0 18px 48px rgba(15,23,42,.16);
  opacity: 0; visibility: hidden; transform: translateY(8px); pointer-events: none;
  transition: opacity .16s, transform .16s, visibility .16s; z-index: 120;
}
.admin-profile-menu.is-open .admin-profile-popover { opacity: 1; visibility: visible; transform: none; pointer-events: auto; }
.admin-profile-popover-avatar { width: 60px; height: 60px; border-radius: var(--inrep-radius, 10px) !important; background: var(--primary); color: #fff; font-size: 24px; font-weight: 700; display: grid; place-items: center; margin-bottom: 12px; }

/* Main canvas */
.admin-main { background: var(--admin-bg); padding: 24px; min-height: 100vh; }
.admin-page-title { font-family: var(--font-display); font-size: clamp(22px,3vw,32px); font-weight: 700; color: var(--text-dark); margin: 0 0 20px; }
.admin-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; align-items: center; }
.admin-panel, .admin-repo-list-card, .dash-card {
  background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; box-shadow: var(--shadow); overflow: hidden; margin-bottom: 20px;
}
.admin-panel-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--border-light);
}
.admin-panel-header h2 { font-size: 14px; font-weight: 650; color: var(--text-dark); margin: 0; font-family: var(--font-display); }
.admin-panel-body { padding: 20px; }
/* KPI cards */
.metric-card {
  background: #fff; border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important; padding: 20px; box-shadow: var(--shadow);
}
.metric-card strong, .kpi-number { font-family: var(--font-display); font-size: 32px; font-weight: 700; color: var(--text-dark); display: block; }
.metric-card span, .kpi-label { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--text-muted-dark); display: block; margin-top: 4px; }
.kpi-trend { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: var(--inrep-radius, 10px) !important; margin-top: 8px; }
.kpi-trend.up { background: var(--primary-soft); color: var(--primary-dark); }
.kpi-trend.down { background: #fee2e2; color: #991b1b; }

/* Admin mobile overlay */
.admin-sidebar-overlay { display: none; }

/* =======================================
   FUNCTIONAL REPO WIDGETS
   ======================================= */
.review-list { display: grid; gap: 12px; }
.review-card { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 16px; background: #fff; }
.review-card p { margin: 8px 0; color: var(--text-muted-dark); }
.clean-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.clean-list li { color: var(--text-dark); font-size: 14px; }
.form-grid-compact { display: grid; grid-template-columns: 1fr 140px; gap: 12px; }
.related-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.related-card { display: block; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; padding: 16px; color: inherit; background: #fff; }
.related-card:hover { border-color: var(--primary); }
.related-card small { display: block; margin-top: 8px; color: var(--text-muted-dark); }
.readiness-card { padding: 22px; display: grid; gap: 10px; background: #fff; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; }
.readiness-card b { font-size: 18px; color: var(--text-dark); }
.readiness-card span { position: relative; padding: 12px 12px 12px 38px; border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light); }
.readiness-card span::before { content: ''; position: absolute; left: 13px; top: 50%; width: 14px; height: 14px; border-radius: var(--inrep-radius, 10px) !important; border: 2px solid var(--primary); transform: translateY(-50%); background: #fff; }
.admin-note { border: 1px solid #bfdbfe; background: #dbeafe; color: var(--text-dark); border-radius: var(--inrep-radius, 10px) !important; padding: 14px 16px; }
.tag-cloud, .public-tag-cloud { display: flex; flex-wrap: wrap; gap: 10px; }
.timeline-list { margin: 0; padding-left: 1.25rem; color: var(--text-dark); line-height: 1.75; }
.inline-check { display: inline-flex; align-items: center; gap: .45rem; color: var(--text-muted-dark); font-size: .92rem; }
.project-status-line { display: flex; gap: 8px; flex-wrap: wrap; margin: 10px 0 14px; }
.inline-actions { display: flex; gap: 8px; align-items: center; margin-top: 12px; }
.inline-actions select { max-width: 160px; }
.form-separator { border: 0; border-top: 1px solid var(--border-light); width: 100%; margin: 4px 0; }
.access-mode-card { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
.access-mode-card span { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light); padding: 12px; }
.subscription-price { font-size: 30px; font-weight: 700; color: var(--text-dark); }

/* =======================================
   RESPONSIVE
   ======================================= */
@media (max-width: 1024px) {
  .mkt-nav { padding: 0 20px; grid-template-columns: auto 1fr auto; }
  .mkt-nav-items, .mkt-nav-search, .mkt-nav-actions { display: none; }
  .mkt-nav-toggle { display: inline-flex; justify-self: end; }
  .mkt-hero-grid, .feature-showcase-grid, .workflow-grid { grid-template-columns: 1fr; }
  .mkt-hero-product { transform: none; }
  .cards-grid, .cards-grid-3, .cards-grid-3x2, .audience-grid, .testimonial-grid, .grid-3, .grid-4 { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .resource-grid, .pricing-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .solution-row { grid-template-columns: 1fr; }
  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell,
  body:not(.admin-sidebar-collapsed) .admin-shell { grid-template-columns: minmax(0,1fr); }
  .admin-sidebar, body.admin-sidebar-collapsed .admin-sidebar {
    position: fixed; inset: 0 auto 0 0; width: min(300px,82vw);
    transform: translateX(-105%); z-index: 120;
  }
  body.admin-sidebar-open .admin-sidebar { transform: translateX(0); }
  .admin-topbar-menu { display: inline-flex; }
  .admin-main { padding: 16px; }
  .contact-grid { grid-template-columns: 1fr; }
  .signup-form-grid { grid-template-columns: 1fr; }
  .signup-intro-card { display: none; }
  .project-detail-rebuilt { grid-template-columns: 1fr; }
  .filter-main { grid-template-columns: 1fr 1fr; }
  .repository-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 768px) {
  .hero-h1, .mkt-hero-h1 { font-size: 36px; }
  .cards-grid, .cards-grid-3, .cards-grid-3x2, .audience-grid, .testimonial-grid,
  .grid-2, .grid-3, .grid-4, .resource-grid, .pricing-grid, .docs-grid,
  .repository-grid, .related-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .stat-item:nth-child(2) { border-right: 0; }
  .mkt-footer-inner { grid-template-columns: 1fr; padding: 40px 0 24px; }
  .auth-deco { opacity: .25; }
  .auth-deco--left { left: -60px; width: 200px; }
  .auth-deco--right { right: -60px; width: 190px; }
  .public-form .form-grid-2 { grid-template-columns: 1fr; }
  .form-grid-compact { grid-template-columns: 1fr; }
  .solution-row { grid-template-columns: 1fr; }
  .filter-main { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero-ctas, .mkt-hero-ctas { flex-direction: column; }
  .hero-ctas .btn, .hero-ctas a, .mkt-hero-ctas .btn { width: 100%; }
  .mkt-hero.mkt-hero--dark { padding: 50px 0 64px; }
  .stats-grid { grid-template-columns: 1fr; }
  .stat-item { border-right: 0; border-bottom: 1px solid var(--border-light); }
  .page-hero, .docs-hero { padding: 40px 0 32px; }
  .admin-main { padding: 12px; }
}
@media print {
  body.admin-fullscreen { overflow: visible; height: auto; }
  .admin-sidebar, .admin-topbar, .admin-actions { display: none !important; }
  .admin-shell, .admin-main { display: block; height: auto; overflow: visible; padding: 0; }
  .admin-panel { box-shadow: none; border: 1px solid var(--border-light); }
}

/* =======================================
   TARGETED PATCHES - fix visual bugs
   ======================================= */

/* -- Fix 1: Content above cta-arc.svg decorative overlay --
   The ::after pseudo on .final-cta / .feature-showcase uses
   cta-arc.svg at opacity .9 - it buries buttons and text.
   Raise all direct content above it with z-index. -- */
.final-cta { position: relative; overflow: hidden; }
.final-cta > * { position: relative; z-index: 2; }
.feature-showcase { position: relative; overflow: hidden; }
.feature-showcase-grid { position: relative; z-index: 2; }
.feature-showcase-grid > * { position: relative; z-index: 2; }

/* The decorative arc stays below content */
.final-cta::after,
.feature-showcase::after {
  content: '';
  position: absolute;
  right: -10%; bottom: -28%;
  width: 68%; height: 100%;
  background: url('/assets/img/cta-arc.svg') right bottom / contain no-repeat;
  opacity: .55;          /* was .9 - reduced so content shows through */
  pointer-events: none;
  z-index: 1;            /* above bg, below content */
}

/* -- Fix 2: Access mode cards - text invisible on light bg --
   These spans are inside .feature-showcase (dark bg) but have
   their own light background. Text inherits dark-section white
   color, making it invisible. Force dark text. -- */
.access-mode-card {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  position: relative;
  z-index: 2;
}
.access-mode-card span {
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.95);
  padding: 14px 16px;
  color: var(--text-dark);        /* force dark - was inheriting white */
  font-size: 14px;
  font-weight: 600;
  text-align: center;
}

/* -- Fix 3: Search preview section - missing padding + text -- */
.search-preview-section {
  padding: 60px 0;
  background: #fff;
}
/* Ensure text inside the card is always dark regardless of parent */
.search-preview-card {
  color: var(--text-dark);
  position: relative;
  z-index: 1;
}
.search-preview-row b,
.search-preview-row strong {
  display: block;
  color: var(--text-dark);
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 3px;
}
.search-preview-row span,
.search-preview-row small {
  font-size: 13px;
  color: var(--text-muted-dark);
  display: block;
}

/* -- Fix 4: checklist-card inside dark feature-showcase --
   The white card renders correctly but the dots need explicit
   colors since the parent section has color:var(--text-light). -- */
.checklist-card {
  background: #fff;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
  position: relative;
  z-index: 3;           /* above the ::after arc */
  color: var(--text-dark);
}
.checklist-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--text-dark);
  font-weight: 500;
}
.checklist-dot {
  width: 22px;
  height: 22px;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 2px solid var(--primary);
  background: var(--primary-soft);
  flex-shrink: 0;
  display: grid;
  place-items: center;
}
.checklist-dot::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary);
  display: block;        /* explicit display */
}
/* Also style plain li inside checklist-card as fallback */
.checklist-card li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--text-dark);
  font-weight: 500;
  list-style: none;
  padding: 0;
}
.checklist-card ul { padding: 0; margin: 0; }
.checklist-card li::before {
  content: '';
  width: 22px; height: 22px; border-radius: var(--inrep-radius, 10px) !important;
  border: 2px solid var(--primary);
  background: var(--primary-soft);
  flex-shrink: 0;
  display: grid;
  place-items: center;
  /* inner dot via box-shadow instead of ::after (can't nest pseudo) */
  box-shadow: inset 0 0 0 4px var(--primary-soft), inset 0 0 0 6px var(--primary);
}

/* -- Fix 5: Section spacing between floated dark CTA blocks --
   The rounded .final-cta blocks float with margin inside a
   white body. They need breathing room. -- */
.final-cta {
  margin: 0 auto;
  width: min(1320px, calc(100% - 48px));
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(145deg, #042c24 0%, #06332a 100%);
  color: #fff;
  text-align: center;
  padding: 60px 36px;
  box-shadow: 0 24px 60px rgba(4,44,36,.25);
}
/* Sections that wrap a .final-cta need padding so the block has space */
section:has(> .final-cta),
.final-cta-section {
  padding: 48px 24px;
  background: var(--bg-light);
}
/* Fallback for browsers without :has() support */
.mkt-final-wrap { padding: 48px 24px; background: var(--bg-light); }

.final-cta h2 {
  font-family: var(--font-display);
  color: #fff;
  font-size: clamp(20px, 2.6vw, 36px);
  line-height: 1.1;
  letter-spacing: -.03em;
  max-width: 760px;
  margin: 0 auto 16px;
}
.final-cta p { color: rgba(255,255,255,.8); max-width: 600px; margin: 0 auto 28px; }
.final-cta .hero-ctas { justify-content: center; }
.final-cta .btn-hero-secondary { color: #fff; border-color: rgba(255,255,255,.5); }
.final-cta .btn-outline-white { color: #fff; border-color: rgba(255,255,255,.5); }

/* -- Fix 6: feature-showcase link color (was blue, should be green) -- */
.feature-showcase-link, .feature-showcase a.feature-showcase-link {
  color: var(--accent-green);
  font-weight: 600;
}
.feature-showcase-link:hover { color: #fff; }

/* -- Fix 7: Workflow section needs explicit background + padding -- */
.workflow-section {
  background: var(--bg-light);
  padding: 60px 24px;
}
.workflow-grid {
  width: min(1100px, calc(100% - 48px));
  margin: auto;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 32px;
  align-items: start;
}
@media (max-width: 768px) {
  .workflow-grid { grid-template-columns: 1fr; }
  .workflow-panels { min-height: 200px; }
}

/* -- Fix 8: Stats section on home page - cards need border separators not individual card borders -- */
.stats-section.stats-light { background: var(--bg-light); border-top: 1px solid var(--border-light); border-bottom: 1px solid var(--border-light); }
.stats-grid { padding: 0; }


/* =======================================
   CRITICAL VISIBILITY + LAYERING PATCH
   Fixes decorative overlay z-index, invisible text, checklist dots,
   dark block spacing, CTA readability, and search preview contrast.
   ======================================= */

.final-cta,
.feature-showcase,
.testimonial-section,
.audience-section.dark,
.bg-dark,
.bg-dark-2,
[class*="dark"],
[class*="cta"] {
  position: relative;
  isolation: isolate;
}

.final-cta::before,
.final-cta::after,
.feature-showcase::before,
.feature-showcase::after,
.testimonial-section::before,
.testimonial-section::after,
.audience-section.dark::before,
.audience-section.dark::after,
.bg-dark::before,
.bg-dark::after,
.bg-dark-2::before,
.bg-dark-2::after,
[class*="cta"]::before,
[class*="cta"]::after {
  pointer-events: none;
  z-index: 0 !important;
  opacity: .38 !important;
}

.final-cta > *,
.feature-showcase > *,
.testimonial-section > *,
.audience-section.dark > *,
.bg-dark > *,
.bg-dark-2 > *,
[class*="cta"] > * {
  position: relative;
  z-index: 2;
}

.final-cta .btn,
.final-cta a,
.final-cta button,
.feature-showcase .btn,
.feature-showcase a,
.feature-showcase button,
.audience-section.dark .btn,
.audience-section.dark a,
.audience-section.dark button,
.bg-dark .btn,
.bg-dark a,
.bg-dark button,
.bg-dark-2 .btn,
.bg-dark-2 a,
.bg-dark-2 button {
  position: relative;
  z-index: 4;
}

.final-cta p,
.feature-showcase p,
.testimonial-section p,
.audience-section.dark p,
.bg-dark p,
.bg-dark-2 p {
  color: rgba(240,247,240,.88) !important;
}

.final-cta h1,
.final-cta h2,
.final-cta h3,
.feature-showcase h1,
.feature-showcase h2,
.feature-showcase h3,
.testimonial-section h1,
.testimonial-section h2,
.testimonial-section h3,
.audience-section.dark h1,
.audience-section.dark h2,
.audience-section.dark h3,
.bg-dark h1,
.bg-dark h2,
.bg-dark h3,
.bg-dark-2 h1,
.bg-dark-2 h2,
.bg-dark-2 h3 {
  color: #fff !important;
}

.access-mode-card,
.access-mode-card *,
.checklist-card,
.checklist-card *,
.search-preview-card,
.search-preview-card *,
.readiness-card,
.readiness-card *,
.feature-showcase .checklist-card,
.feature-showcase .checklist-card *,
.bg-dark .checklist-card,
.bg-dark .checklist-card *,
.bg-dark-2 .checklist-card,
.bg-dark-2 .checklist-card * {
  color: var(--text-dark) !important;
}

.access-mode-card {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.access-mode-card span,
.access-mode-card li,
.access-mode-card div {
  min-height: 56px;
  display: flex;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-dark) !important;
  font-weight: 650;
  opacity: 1 !important;
}

.search-preview-section {
  padding: 88px 0 !important;
  width: min(1200px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
  color: var(--text-dark) !important;
}

.search-preview-card {
  position: relative;
  z-index: 3;
  background: #fff !important;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}

.search-preview-row,
.search-preview-row *,
.search-preview-bar,
.search-preview-bar * {
  color: var(--text-dark) !important;
  opacity: 1 !important;
}

.search-preview-row span,
.search-preview-bar,
.search-preview-bar span {
  color: var(--text-muted-dark) !important;
}

.checklist-card {
  position: relative;
  z-index: 4;
  background: #fff !important;
  opacity: 1 !important;
}

.checklist-item {
  position: relative;
  z-index: 5;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}

.checklist-dot {
  position: relative;
  display: inline-grid !important;
  place-items: center;
  flex: 0 0 20px;
  width: 20px !important;
  height: 20px !important;
  border: 2px solid var(--primary) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary-soft) !important;
}

.checklist-dot::after {
  content: '' !important;
  display: block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary) !important;
}

.checklist-card li,
.checklist-card > span,
.checklist-card > div:not(.checklist-item) {
  color: var(--text-dark) !important;
  opacity: 1 !important;
}

section:has(.final-cta),
.section:has(.final-cta),
.cards-section:has(.final-cta),
.feature-showcase + .final-cta,
.final-cta + .mkt-footer,
.final-cta + section {
  margin-top: 48px;
}

.final-cta {
  margin-block: 48px;
  border-radius: var(--inrep-radius, 10px) !important;
  overflow: hidden;
}

main > .final-cta,
main > section.final-cta {
  width: min(1200px, calc(100% - 48px));
  margin-inline: auto;
}

.cards-section + .final-cta,
.feature-showcase + .final-cta,
.audience-section + .final-cta,
.search-preview-section + .final-cta,
.workflow-section + .final-cta {
  margin-top: 48px;
}

.mkt-hero-product,
.mkt-hero-product * {
  position: relative;
}

.mkt-hero-product::before,
.mkt-hero-product::after {
  pointer-events: none;
  z-index: 0 !important;
  opacity: .35 !important;
}

.mkt-hero-product .product-record,
.mkt-hero-product .product-search,
.mkt-hero-product .product-metrics,
.mkt-hero-product .product-chrome {
  z-index: 2;
}

.product-record strong {
  color: rgba(255,255,255,.96) !important;
}

.product-record span,
.product-record small {
  color: rgba(255,255,255,.66) !important;
}

.feature-showcase .feature-showcase-grid,
.audience-section.dark .audience-grid,
.bg-dark .feature-showcase-grid,
.bg-dark-2 .feature-showcase-grid {
  position: relative;
  z-index: 2;
}

.contact-card,
.contact-card *,
.public-form,
.public-form * {
  color: var(--text-dark);
}

.public-form button,
.contact-card .btn,
.contact-card button[type="submit"] {
  color: #fff !important;
}

@media (max-width: 768px) {
  .search-preview-section {
    grid-template-columns: 1fr !important;
    padding: 64px 0 !important;
  }

  .access-mode-card {
    grid-template-columns: 1fr;
  }

  .final-cta {
    width: min(100% - 24px, 1200px) !important;
    margin-block: 32px;
    padding: 56px 20px !important;
  }
}


/* ===============================================
   ROUND 3 UI FIXES - visibility, spacing, modal, layout
   =============================================== */

/* Keyboard shortcut modal */
.shortcut-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(10,31,21,.6);
  backdrop-filter: blur(4px);
  place-items: center;
}
.shortcut-modal.is-open { display: grid; }
.shortcut-card {
  background: #fff;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 28px;
  width: min(480px, calc(100vw - 48px));
  box-shadow: 0 32px 80px rgba(0,0,0,.3);
}
.shortcut-card h2 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--text-dark);
  margin: 0 0 16px;
}
.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.shortcut-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-light);
  font-size: 14px;
  color: var(--text-dark);
}
.shortcut-row:last-child { border-bottom: 0; }
.shortcut-row kbd {
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dark);
  font-family: var(--font-body);
}

/* Offline/PWA notification must not render as plain text below the footer */
.offline-indicator,
.offline-toast,
.offline-bar,
.pwa-toast,
[data-offline] {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--text-dark);
  color: #fff;
  padding: 10px 18px;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 13px;
  line-height: 1.3;
  z-index: 400;
  display: none;
  align-items: center;
  gap: 8px;
  box-shadow: 0 16px 48px rgba(0,0,0,.18);
}
body.is-offline .offline-indicator,
body.is-offline .offline-toast,
body.is-offline .offline-bar,
body.is-offline .pwa-toast,
body.is-offline [data-offline] {
  display: flex;
}

/* Light page hero buttons */
.page-hero .btn-hero-secondary,
.page-hero .hero-ctas .btn-hero-secondary,
.hero-actions .btn-hero-secondary {
  background: transparent;
  border: 1.5px solid var(--border-light);
  color: var(--text-dark);
}
.page-hero .btn-hero-secondary:hover,
.hero-actions .btn-hero-secondary:hover {
  background: var(--bg-light);
  border-color: var(--primary);
  color: var(--primary);
}
.page-hero .btn-hero-primary,
.hero-actions .btn-hero-primary {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-top: 20px;
}

/* Feature showcase structure */
.feature-showcase {
  position: relative;
  isolation: isolate;
  background: var(--bg-dark);
  color: var(--text-light);
  padding: 80px min(60px, 4vw);
  overflow: hidden;
}
.feature-showcase::before,
.feature-showcase::after,
.final-cta::before,
.final-cta::after {
  pointer-events: none;
  z-index: 0 !important;
  opacity: .38 !important;
}
.feature-showcase > *,
.final-cta > * {
  position: relative;
  z-index: 2;
}
.feature-showcase-grid {
  width: min(1200px, calc(100% - 48px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.feature-showcase-grid > * { min-width: 0; }
.feature-showcase h1,
.feature-showcase h2,
.feature-showcase h3,
.feature-showcase .section-title {
  color: #fff !important;
}
.feature-showcase p {
  color: rgba(240,247,240,.88) !important;
}

/* Contact form rows */
.form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.contact-card .public-form {
  display: grid;
  gap: 16px;
}
.contact-card .public-form label,
.contact-card .public-form input,
.contact-card .public-form select,
.contact-card .public-form textarea {
  color: var(--text-dark);
}
.contact-card .public-form button {
  color: #fff !important;
}

/* Explore/projects spacing */
.page-hero.compact { padding: 48px 0 32px; }
.page-hero.compact .hero-h1 {
  font-size: clamp(32px, 4.5vw, 52px);
  margin-bottom: 12px;
}
.repository-browser { padding: 24px 0 60px; }
.repository-filter-card { margin-bottom: 20px; }

/* Stats strip */
.stats-section { padding: 48px 0; }
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: min(960px, calc(100% - 48px));
  margin: 0 auto;
}
.stat-item {
  padding: 20px 16px;
  text-align: center;
  border-right: 1px solid var(--border-light);
}
.stats-dark .stat-item { border-right-color: var(--border-dark); }
.stat-item:last-child { border-right: 0; }
.stat-number,
.stat-value {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.1;
  color: inherit;
  display: block;
  margin-bottom: 4px;
}
.stat-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted-dark);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.stats-dark .stat-number,
.stats-dark .stat-value { color: #fff; }
.stats-dark .stat-label { color: var(--text-muted-light); }

/* Spacing rhythm */
.cards-section { padding: 80px 0; }
.cards-section .section-heading { margin-bottom: 48px; }
.cards-grid,
.cards-grid-3,
.cards-grid-3x2 {
  width: min(1160px, calc(100% - 48px));
  margin: 0 auto;
}
.audience-section { padding: 80px 0; }
.audience-grid {
  width: min(1160px, calc(100% - 48px));
  margin: 0 auto;
  gap: 16px;
}
.testimonial-section { padding: 80px 0; }
.final-cta {
  margin: 48px auto;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.search-preview-section {
  padding: 80px 24px;
  color: var(--text-dark);
}

/* Resource/docs links */
.resource-card a,
.docs-card a {
  color: var(--primary);
  font-weight: 500;
}
.resource-card a:hover,
.docs-card a:hover {
  color: var(--primary-dark);
  text-decoration: underline;
}
.resource-card ul li {
  color: var(--text-muted-dark);
  font-size: 14px;
  line-height: 1.7;
}

/* Audience card labels */
.audience-card {
  padding: 20px 22px;
  gap: 10px;
}
.audience-card strong {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-dark);
  display: block;
}
.audience-card small {
  font-size: 13px;
  color: var(--text-muted-dark);
  display: block;
  line-height: 1.5;
}
.audience-card .mini-dot { margin-bottom: 6px; }

/* Feature card icon visibility */
.feature-card-icon svg {
  color: var(--accent-green);
  display: block;
}
.feature-card:hover .feature-card-icon { background: var(--primary); }
.feature-card:hover .feature-card-icon svg { color: #fff; }

/* Light cards inside dark sections must stay readable */
.access-mode-card,
.access-mode-card *,
.checklist-card,
.checklist-card *,
.search-preview-card,
.search-preview-card *,
.readiness-card,
.readiness-card * {
  color: var(--text-dark) !important;
}
.access-mode-card {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.access-mode-card span,
.access-mode-card li,
.access-mode-card div {
  min-height: 56px;
  display: flex;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-dark) !important;
  font-weight: 650;
  opacity: 1 !important;
}
.search-preview-card {
  position: relative;
  z-index: 3;
  background: #fff !important;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.search-preview-row,
.search-preview-row *,
.search-preview-bar,
.search-preview-bar * {
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.search-preview-row span,
.search-preview-bar,
.search-preview-bar span {
  color: var(--text-muted-dark) !important;
}

/* Checklist visibility */
.checklist-card {
  position: relative;
  z-index: 4;
  background: #fff !important;
  opacity: 1 !important;
}
.checklist-item {
  position: relative;
  z-index: 5;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.checklist-dot {
  position: relative;
  display: inline-grid !important;
  place-items: center;
  flex: 0 0 20px;
  width: 20px !important;
  height: 20px !important;
  border: 2px solid var(--primary) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary-soft) !important;
}
.checklist-dot::after {
  content: '' !important;
  display: block !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary) !important;
}

/* Dark CTA buttons/text above decoration */
.final-cta .btn,
.final-cta a,
.final-cta button {
  position: relative;
  z-index: 4;
}
.final-cta p { color: rgba(240,247,240,.88) !important; }
.final-cta h1,
.final-cta h2,
.final-cta h3 { color: #fff !important; }

@media (max-width: 900px) {
  .feature-showcase-grid,
  section.feature-showcase {
    grid-template-columns: 1fr;
    padding: 60px 24px;
    gap: 36px;
  }
  .feature-showcase-grid {
    width: 100%;
  }
  section.feature-showcase > div {
    padding: 0;
    width: 100%;
    max-width: 100%;
    margin: 0;
  }
  .checklist-card { width: 100%; }
  .access-mode-card {
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
  }
}
@media (max-width: 640px) {
  .form-row-2 { grid-template-columns: 1fr; }
  .access-mode-card { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .stats-grid { grid-template-columns: 1fr; }
  .stat-item { border-right: 0; border-bottom: 1px solid var(--border-light); }
  .stat-item:last-child { border-bottom: 0; }
}



/* ===============================================
   DASHBOARD RECOVERY PATCH
   Fixes scattered admin shell, misplaced grid children,
   huge SVG/search icons, blank canvas, responsive topbar,
   sidebar collapse/expand, and dashboard card layout.
   =============================================== */

/* Admin shell must use explicit grid areas, not auto-placement */
body.admin-fullscreen {
  min-height: 100dvh;
  height: 100dvh;
  overflow: hidden;
  background: var(--admin-bg);
}

.admin-shell {
  min-height: 100dvh;
  height: 100dvh;
  display: grid;
  grid-template-columns: var(--admin-sidebar-width-expanded) minmax(0, 1fr);
  grid-template-rows: 64px auto minmax(0, 1fr);
  grid-template-areas:
    "sidebar topbar"
    "sidebar banner"
    "sidebar main";
  background: var(--admin-bg);
  overflow: hidden;
  transition: grid-template-columns .2s ease;
}

body.admin-sidebar-collapsed .admin-shell {
  grid-template-columns: var(--admin-sidebar-width-collapsed) minmax(0, 1fr);
}

.admin-sidebar {
  grid-area: sidebar;
  position: relative;
  inset: auto;
  width: auto;
  height: 100dvh;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  background: var(--admin-sidebar-bg);
  border-right: 1px solid rgba(255,255,255,.08);
  padding: 12px 8px 20px;
  z-index: 120;
  transform: none;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.32) transparent;
}

.admin-sidebar::-webkit-scrollbar { width: 6px; }
.admin-sidebar::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.28);
  border-radius: var(--inrep-radius, 10px) !important;
}

.admin-sidebar-overlay {
  display: none;
  grid-area: main;
}

.admin-topbar {
  grid-area: topbar;
  position: sticky;
  top: 0;
  z-index: 100;
  min-width: 0;
  height: 64px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 18px;
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid var(--border-light);
  backdrop-filter: blur(14px);
  overflow: visible;
}

.admin-readiness-banner {
  grid-area: banner;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding: 10px 18px;
  background: #ecfdf3;
  color: #14532d;
  border-bottom: 1px solid #bbf7d0;
  font-size: 13px;
  line-height: 1.35;
}

.admin-readiness-banner[hidden],
.admin-readiness-banner.is-hidden {
  display: none !important;
}

.admin-readiness-banner-text {
  min-width: 0;
  flex: 1;
}

.admin-readiness-banner a {
  color: var(--primary-dark);
  font-weight: 700;
}

.admin-readiness-banner-close {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: var(--inrep-radius, 10px) !important;
  color: #14532d;
  background: transparent;
}

.admin-readiness-banner-close:hover {
  background: rgba(20,83,45,.08);
}

.admin-main {
  grid-area: main;
  min-width: 0;
  min-height: 0;
  height: 100%;
  overflow: auto;
  padding: 28px;
  isolation: isolate;
  background:
    radial-gradient(circle at 88% -10%, rgba(29,185,84,.07), transparent 34%),
    var(--admin-bg);
}

/* Stop global SVG rules from making icons huge */
.admin-shell svg,
.admin-topbar svg,
.admin-sidebar svg,
.admin-main svg,
.admin-icon-btn svg,
.admin-search svg,
.admin-sidebar-link svg,
.admin-sidebar-pin svg,
.admin-topbar-menu svg,
.admin-sidebar-collapse-toggle svg,
.admin-sidebar-close svg {
  width: 18px !important;
  height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  display: block;
  flex: 0 0 auto;
  stroke-width: 2;
}

.admin-sidebar-brand .inrep-mark,
.admin-topbar .mkt-nav-logo .inrep-mark,
.admin-profile-popover-avatar,
.admin-profile-avatar-large,
.admin-avatar {
  flex: 0 0 auto;
}

/* Sidebar structure */
.admin-sidebar-header {
  display: grid;
  grid-template-columns: minmax(0,1fr) 36px;
  align-items: center;
  gap: 8px;
  padding: 0 0 12px;
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.admin-sidebar-brand {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 15px;
  letter-spacing: -.02em;
}

.admin-sidebar-brand .inrep-mark {
  width: 38px;
  height: 38px;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), #0f5f3e);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}

.admin-sidebar-brand span:not(.inrep-mark) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-sidebar-collapse-toggle,
.admin-sidebar-close,
.admin-topbar-menu {
  width: 38px;
  height: 38px;
  display: inline-grid;
  place-items: center;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.07);
  color: var(--text-muted-light);
}

.admin-topbar-menu {
  border-color: var(--border-light);
  background: #fff;
  color: var(--text-dark);
}

.admin-sidebar-close {
  display: none;
}

.admin-sidebar-section {
  display: grid;
  gap: 2px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.admin-sidebar-section[hidden] {
  display: none !important;
}

.admin-sidebar-label {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px 6px;
  color: rgba(255,255,255,.42);
  font-size: 10px;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 800;
}

.admin-sidebar-links {
  display: grid;
  gap: 2px;
}

.admin-sidebar-section.is-collapsed .admin-sidebar-links {
  display: none;
}

.admin-sidebar-item {
  position: relative;
  display: flex;
  align-items: center;
  min-width: 0;
}

.admin-sidebar-link {
  min-width: 0;
  width: 100%;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 0 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  color: rgba(240,247,240,.72);
  background: transparent;
  font-size: 13px;
  font-weight: 650;
  line-height: 1;
  text-decoration: none;
}

.admin-sidebar-link span {
  min-width: 0;
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-sidebar-link:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.admin-sidebar-link.active {
  background: rgba(29,185,84,.18);
  color: #fff;
}

.admin-sidebar-link.active svg {
  color: var(--accent-green);
}

.admin-sidebar-link .admin-sidebar-pin {
  flex: none;
  margin-left: auto;
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  color: rgba(255,255,255,.45);
  font-size: 0;
  line-height: 1;
  opacity: 0;
  transition: opacity .15s ease, background .15s ease, color .15s ease;
}
.admin-sidebar-link .admin-sidebar-pin svg {
  display: block;
  width: 11px;
  height: 11px;
  flex-shrink: 0;
}

.admin-sidebar-link:hover .admin-sidebar-pin,
.admin-sidebar-link:focus-within .admin-sidebar-pin {
  opacity: .55;
}

.admin-sidebar-link .admin-sidebar-pin:hover {
  background: rgba(255,255,255,.10);
  color: #fff;
  opacity: 1;
}

/* Collapsed desktop sidebar */
body.admin-sidebar-collapsed .admin-sidebar {
  padding-inline: 8px;
}

body.admin-sidebar-collapsed .admin-sidebar-header {
  grid-template-columns: 1fr;
  justify-items: center;
}

body.admin-sidebar-collapsed .admin-sidebar-brand span:not(.inrep-mark),
body.admin-sidebar-collapsed .admin-sidebar-label,
body.admin-sidebar-collapsed .admin-sidebar-link span,
body.admin-sidebar-collapsed .admin-sidebar-pin {
  display: none !important;
}

body.admin-sidebar-collapsed .admin-sidebar-brand {
  justify-content: center;
}

body.admin-sidebar-collapsed .admin-sidebar-link {
  width: 40px;
  height: 40px;
  justify-content: center;
  padding: 0;
  margin-inline: auto;
}

body.admin-sidebar-collapsed .admin-sidebar-section {
  align-items: center;
}

body.admin-sidebar-collapsed .admin-sidebar-collapse-toggle {
  width: 40px;
  height: 40px;
  margin-inline: auto;
}

/* Topbar */
.admin-topbar .mkt-nav-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.admin-topbar .mkt-nav-logo .inrep-mark {
  width: 38px;
  height: 38px;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid;
  place-items: center;
  background: var(--bg-dark);
  color: #fff;
}

.admin-topbar-title {
  min-width: max-content;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
}

.admin-search {
  width: min(380px, 32vw);
  min-width: 220px;
  height: 40px;
  margin-left: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
  color: var(--text-muted-dark);
  flex: 0 1 380px;
}

.admin-search input {
  min-width: 0;
  min-height: 0;
  height: 38px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--text-dark);
  font-size: 14px;
}

.admin-topbar-actions {
  margin-left: auto;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-icon-btn,
.admin-topbar-action-labeled,
.admin-logout-button,
.admin-profile-trigger {
  flex: 0 0 auto;
}

.admin-icon-btn {
  min-width: 38px;
  width: auto;
  height: 38px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-muted-dark);
  font-weight: 700;
  font-size: 13px;
  position: relative;
}

.admin-icon-btn:hover {
  background: var(--bg-light);
  color: var(--text-dark);
}

.admin-mobile-search-btn {
  display: none;
}

.admin-icon-label {
  display: inline-block;
}

.admin-count-badge {
  position: absolute;
  top: -7px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #ef4444;
  color: #fff;
  border: 2px solid #fff;
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
}

.admin-count-badge[hidden] {
  display: none !important;
}

.admin-avatar {
  width: 38px;
  height: 38px;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--primary), #2563eb);
  color: #fff;
  font-weight: 800;
}

.admin-logout-form {
  margin: 0;
}

.admin-logout-button {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-dark);
  font-weight: 700;
}

.admin-profile-popover {
  color: var(--text-dark);
}

.admin-profile-popover-main {
  display: grid;
  gap: 2px;
  margin-bottom: 12px;
}

.admin-profile-popover-main strong {
  color: var(--text-dark);
  font-size: 16px;
}

.admin-profile-popover-main span,
.admin-profile-popover-meta dt {
  color: var(--text-muted-dark);
  font-size: 13px;
}

.admin-profile-popover-meta {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
}

.admin-profile-popover-meta div {
  display: grid;
  gap: 2px;
}

.admin-profile-popover-meta dt,
.admin-profile-popover-meta dd {
  margin: 0;
}

.admin-profile-popover-edit {
  width: 100%;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 8px;
  padding: 8px 12px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-dark);
  font-weight: 700;
}

.admin-profile-popover-edit.danger {
  color: #b42318;
}

.admin-profile-logout-form {
  margin: 0;
}

/* Dashboard content */
.admin-page {
  width: min(1280px, 100%);
  margin: 0 auto;
}

.admin-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.admin-page-title {
  margin: 0;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.05;
  letter-spacing: -.035em;
}

.admin-page-subtitle {
  max-width: 760px;
  margin: 8px 0 0;
  color: var(--text-muted-dark);
  font-size: 15px;
}

.admin-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  color: var(--text-muted-dark);
  font-size: 13px;
}

.admin-breadcrumbs a {
  color: var(--blue);
}

.admin-breadcrumbs strong {
  color: var(--text-dark);
}

.admin-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-profile-overview {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  gap: 18px;
  margin-bottom: 18px;
}

.admin-profile-card,
.admin-repo-list-card,
.admin-panel,
.metric-card {
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: var(--shadow);
}

.admin-profile-card {
  padding: 22px;
  display: grid;
  gap: 12px;
  align-content: start;
}

.admin-profile-avatar-large {
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(135deg, var(--primary), #2563eb);
  color: #fff;
  font-size: 28px;
  font-weight: 900;
  box-shadow: 0 10px 30px rgba(29,185,84,.22);
}

.admin-profile-card h2 {
  margin: 0;
  color: var(--text-dark);
  font-size: 18px;
}

.admin-profile-card p {
  margin: -8px 0 0;
  color: var(--text-muted-dark);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.admin-profile-card .btn.full {
  width: 100%;
}

.admin-profile-facts {
  list-style: none;
  display: grid;
  gap: 10px;
  margin: 8px 0 0;
  padding: 12px 0 0;
  border-top: 1px solid var(--border-light);
}

.admin-profile-facts li {
  display: grid;
  gap: 2px;
}

.admin-profile-facts span {
  color: var(--text-muted-dark);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.admin-profile-facts strong {
  color: var(--text-dark);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.panel-head,
.admin-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-light);
}

.panel-head h2,
.admin-panel-header h2,
.admin-repo-list-card h2 {
  margin: 0;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: -.02em;
}

.panel-head p {
  margin: 4px 0 0;
  color: var(--text-muted-dark);
  font-size: 14px;
}

.admin-repo-list-card {
  overflow: hidden;
}

.admin-repo-list {
  display: grid;
}

.admin-repo-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  border-top: 1px solid var(--border-light);
  color: var(--text-dark);
}

.admin-repo-row:first-child {
  border-top: 0;
}

.admin-repo-row:hover {
  background: var(--bg-light);
  color: var(--text-dark);
}

.admin-repo-row span {
  display: grid;
  gap: 3px;
}

.admin-repo-row strong {
  color: var(--blue);
  font-size: 14px;
}

.admin-repo-row small,
.admin-repo-row em {
  color: var(--text-muted-dark);
  font-style: normal;
  font-size: 13px;
}

.admin-grid {
  display: grid;
  gap: 18px;
}

.admin-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.admin-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.admin-grid-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }

.mb-16 {
  margin-bottom: 18px;
}
.mt-4 { margin-top: 16px; }

.metric-card {
  padding: 20px;
  min-width: 0;
}

.metric-card span,
.metric-card small {
  display: block;
  color: var(--text-muted-dark);
  font-size: 13px;
}

.metric-card strong {
  display: block;
  margin: 6px 0 3px;
  color: var(--text-dark);
  font-family: var(--font-display);
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.03em;
}

.admin-panel {
  overflow: hidden;
}

.admin-panel > .panel-head {
  padding: 18px 20px;
}

.admin-panel-body {
  padding: 20px;
}

.health-list {
  display: grid;
  gap: 10px;
  padding: 18px 20px;
}

.health-item {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
  color: var(--text-dark);
}

.health-item:hover {
  border-color: rgba(29,185,84,.35);
  background: #fff;
}

.health-item span {
  min-width: 0;
  color: var(--text-dark);
  font-size: 14px;
  font-weight: 650;
}

.health-item strong {
  color: var(--text-dark);
  font-weight: 800;
}

.admin-table-wrap {
  overflow-x: auto;
  padding: 0 20px 20px;
}

.admin-empty-state {
  margin: 20px;
  min-height: 180px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 28px;
  border: 1px dashed var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
  text-align: center;
}

.admin-empty-state strong {
  color: var(--text-dark);
  font-size: 18px;
}

.admin-empty-state span {
  color: var(--text-muted-dark);
  max-width: 360px;
}

/* Tables and wide admin pages */
.admin-table,
.admin-panel table,
.admin-table-wrap table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
}

.admin-table-wrap,
.table-responsive {
  max-width: 100%;
  overflow-x: auto;
}

/* Responsive admin layout */
@media (max-width: 1180px) {
  .admin-grid-5 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .admin-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-profile-overview { grid-template-columns: 1fr; }
}

@media (max-width: 1023px) {
  body.admin-fullscreen {
    overflow: hidden;
  }

  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell,
  body:not(.admin-sidebar-collapsed) .admin-shell {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: 60px auto minmax(0, 1fr);
    grid-template-areas:
      "topbar"
      "banner"
      "main";
  }

  .admin-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(320px, 86vw);
    height: 100dvh;
    transform: translateX(-105%);
    transition: transform .22s ease;
    z-index: 220;
    box-shadow: 24px 0 80px rgba(0,0,0,.28);
  }

  body.admin-sidebar-open .admin-sidebar {
    transform: translateX(0);
  }

  .admin-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 210;
    background: rgba(10,31,21,.45);
    backdrop-filter: blur(2px);
  }

  body.admin-sidebar-open .admin-sidebar-overlay {
    display: block;
  }

  .admin-sidebar-close {
    display: inline-grid;
  }

  .admin-sidebar-header {
    grid-template-columns: minmax(0, 1fr) 36px;
  }

  body.admin-sidebar-collapsed .admin-sidebar-brand span:not(.inrep-mark),
  body.admin-sidebar-collapsed .admin-sidebar-label,
  body.admin-sidebar-collapsed .admin-sidebar-link span {
    display: inline-block !important;
  }

  .admin-topbar {
    height: 60px;
    padding: 0 12px;
    gap: 8px;
  }

  .admin-topbar-menu {
    display: inline-grid;
  }

  .admin-search {
    display: none;
  }

  .admin-mobile-search-btn {
    display: inline-flex;
  }

  .admin-topbar-title {
    min-width: 0;
    max-width: 32vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 14px;
  }

  .admin-topbar-action-labeled {
    width: 38px;
    padding: 0;
  }

  .admin-icon-label,
  .admin-logout-form {
    display: none !important;
  }

  .admin-main {
    padding: 16px;
  }

  .admin-page-header {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 760px) {
  .admin-readiness-banner {
    align-items: flex-start;
    padding: 10px 12px;
    font-size: 12px;
  }

  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4,
  .admin-grid-5 {
    grid-template-columns: 1fr;
  }

  .admin-profile-card,
  .admin-panel,
  .admin-repo-list-card,
  .metric-card {
    border-radius: var(--inrep-radius, 10px) !important;
  }

  .panel-head,
  .admin-panel-header,
  .admin-repo-row,
  .health-list {
    padding-inline: 14px;
  }

  .admin-repo-row,
  .health-item {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-main {
    padding: 14px;
  }
}

@media (max-width: 520px) {
  .admin-topbar .mkt-nav-logo {
    display: none;
  }

  .admin-topbar-title {
    max-width: 38vw;
  }

  .admin-icon-btn {
    min-width: 36px;
    height: 36px;
    padding: 0 8px;
  }

  .admin-avatar {
    width: 36px;
    height: 36px;
  }

  .admin-main {
    padding: 12px;
  }
}

/* Print reset */
@media print {
  body.admin-fullscreen {
    height: auto;
    overflow: visible;
  }

  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell {
    display: block;
    height: auto;
    overflow: visible;
  }

  .admin-sidebar,
  .admin-topbar,
  .admin-readiness-banner,
  .admin-actions {
    display: none !important;
  }

  .admin-main {
    display: block;
    height: auto;
    overflow: visible;
    padding: 0;
  }
}



/* ===============================================
   PUBLIC WEBSITE SPACING RECOVERY PATCH
   Fixes tight contact/support sections and normalizes
   top/bottom breathing room across public pages.
   =============================================== */

:root {
  --section-y: clamp(72px, 8vw, 124px);
  --section-y-sm: clamp(48px, 6vw, 84px);
  --section-gap: clamp(28px, 4vw, 56px);
}

/* Give all public page blocks enough top/bottom rhythm */
main > section,
.public-main > section,
.mkt-page > section,
.mkt-main > section,
.page-section,
.mkt-section,
.cards-section,
.workflow-section,
.audience-section,
.search-preview-section,
.testimonial-section,
.pricing-section,
.faq-section,
.repository-browser,
.docs-section,
.resource-section,
.solution-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}

/* Prevent stacked sections from touching visually */
main > section + section,
.public-main > section + section,
.mkt-page > section + section,
.mkt-main > section + section {
  margin-top: 0;
}

/* Contact page: the screenshot issue */
.contact-grid {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
  align-items: center;
}

.contact-card {
  padding: clamp(28px, 4vw, 48px);
}

.contact-support-grid {
  gap: clamp(14px, 2vw, 22px);
  margin-top: clamp(24px, 3vw, 36px);
}

.contact-support-grid div {
  padding: clamp(18px, 2.3vw, 26px) 0;
}

.contact-support-grid div:first-child {
  padding-top: 0;
}

.contact-support-grid div:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.contact-grid .public-form,
.contact-card .public-form {
  gap: clamp(16px, 2vw, 24px);
}

.contact-grid textarea,
.contact-card textarea {
  min-height: 150px;
}

.contact-grid button[type="submit"],
.contact-card button[type="submit"] {
  margin-top: 8px;
}

/* Large rounded content slabs need inner breathing room */
.section-soft,
.mkt-light,
.cards-section.mkt-light,
.workflow-section,
.pricing-section,
.contact-section,
.docs-section,
.resources-section,
.solution-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}

.section-heading,
.cards-section-header,
.cards-section .section-heading {
  margin-bottom: var(--section-gap);
}

/* Dark CTA/showcase blocks: keep decorative art behind content and add spacing */
.feature-showcase,
.final-cta,
.cta-section,
.dark-cta,
.repository-cta,
.launch-cta {
  position: relative;
  isolation: isolate;
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
  margin-top: var(--section-y-sm);
  margin-bottom: var(--section-y-sm);
  overflow: hidden;
}

.feature-showcase > *,
.final-cta > *,
.cta-section > *,
.dark-cta > *,
.repository-cta > *,
.launch-cta > * {
  position: relative;
  z-index: 2;
}

.feature-showcase::before,
.feature-showcase::after,
.final-cta::before,
.final-cta::after,
.cta-section::before,
.cta-section::after,
.dark-cta::before,
.dark-cta::after,
.repository-cta::before,
.repository-cta::after,
.launch-cta::before,
.launch-cta::after {
  z-index: 0;
  pointer-events: none;
}

/* Cards and grids need consistent vertical spacing */
.cards-grid,
.cards-grid-3,
.cards-grid-3x2,
.projects-public-grid,
.resource-grid,
.docs-grid,
.audience-grid,
.testimonial-grid,
.pricing-grid,
.repository-grid {
  margin-top: var(--section-gap);
}

.admin-panel + .admin-panel,
.card + .card,
.feature-card + .feature-card {
  margin-top: 0;
}

/* Forms should not look compressed */
.public-form .form-grid-2,
.form-grid-2 {
  gap: clamp(16px, 2vw, 24px);
}

.form-group {
  margin-bottom: clamp(16px, 2vw, 22px);
}

input,
select,
textarea {
  min-height: 48px;
}

.btn,
.btn-hero-primary,
.btn-hero-secondary,
.mkt-nav-signup,
.btn-new-repo {
  min-height: 46px;
}

/* Search/filter blocks */
.repository-filter-card,
.search-preview-card,
.docs-search,
.help-panel {
  margin-top: var(--section-gap);
  margin-bottom: var(--section-gap);
}

.search-preview-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
  color: var(--text-dark);
}

.search-preview-card,
.search-preview-row,
.search-preview-row b,
.search-preview-row span {
  color: var(--text-dark);
}

.search-preview-row span {
  color: var(--text-muted-dark);
}

/* Page hero should breathe before next content block */
.page-hero,
.docs-hero {
  padding-top: clamp(72px, 8vw, 112px);
  padding-bottom: clamp(56px, 6vw, 88px);
}

.page-hero + section,
.docs-hero + section {
  padding-top: var(--section-y-sm);
}

/* Footer should not crowd the previous section */
.mkt-footer {
  margin-top: 0;
}

main > section:last-of-type:not(.final-cta):not(.feature-showcase) {
  padding-bottom: var(--section-y);
}

/* Responsive tightening without removing breathing room */
@media (max-width: 1024px) {
  :root {
    --section-y: clamp(56px, 9vw, 88px);
    --section-y-sm: clamp(40px, 7vw, 64px);
  }

  .contact-grid {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
}

@media (max-width: 768px) {
  :root {
    --section-y: 56px;
    --section-y-sm: 36px;
    --section-gap: 28px;
  }

  .container,
  .mkt-container,
  .contact-grid,
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .resource-grid,
  .docs-grid,
  .repository-filter-card,
  .repository-results-head,
  .repository-grid {
    width: min(100% - 28px, 1200px);
  }

  .contact-card {
    padding: 24px;
  }

  .contact-support-grid div {
    padding: 18px 0;
  }

  .feature-showcase,
  .final-cta,
  .cta-section,
  .dark-cta,
  .repository-cta,
  .launch-cta {
    margin-top: 36px;
    margin-bottom: 36px;
  }
}



/* ===============================================
   CONTACT FORM FINAL SPACING PATCH
   Fixes tight top/bottom spacing on contact/support form sections.
   Applies safely across all public forms without changing structure.
   =============================================== */

.contact-section,
section:has(.contact-grid) {
  padding-top: clamp(96px, 9vw, 150px) !important;
  padding-bottom: clamp(96px, 9vw, 150px) !important;
}

.contact-grid {
  width: min(1280px, calc(100% - 64px)) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 560px) !important;
  align-items: center !important;
  gap: clamp(64px, 7vw, 112px) !important;
  margin-inline: auto !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.contact-grid > * {
  min-width: 0;
}

.contact-card {
  padding: clamp(40px, 4.8vw, 64px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 28px 70px rgba(10,31,21,.10) !important;
}

.contact-grid .section-eyebrow,
.contact-grid .hero-eyebrow,
.contact-grid .eyebrow {
  margin-bottom: 22px !important;
}

.contact-grid h1,
.contact-grid h2,
.contact-grid .section-title {
  margin-bottom: clamp(24px, 3vw, 38px) !important;
  line-height: 1.08 !important;
}

.contact-grid p {
  margin-bottom: clamp(30px, 3vw, 46px) !important;
}

.contact-support-grid {
  display: grid !important;
  gap: 0 !important;
  margin-top: clamp(34px, 4vw, 58px) !important;
}

.contact-support-grid div {
  padding: clamp(26px, 3vw, 38px) clamp(18px, 2vw, 28px) !important;
  border-bottom: 1px solid var(--border-light) !important;
}

.contact-support-grid div:first-child {
  padding-top: 0 !important;
}

.contact-support-grid div:last-child {
  padding-bottom: 0 !important;
  border-bottom: 0 !important;
}

.contact-support-grid strong,
.contact-support-grid b {
  display: block !important;
  margin-bottom: 7px !important;
  line-height: 1.25 !important;
}

.contact-support-grid span,
.contact-support-grid p {
  display: block !important;
  margin: 0 !important;
  line-height: 1.65 !important;
}

.contact-card .public-form,
.contact-grid .public-form,
.public-form.contact-form {
  display: grid !important;
  gap: clamp(22px, 2.4vw, 32px) !important;
}

.contact-card .public-form .form-grid-2,
.contact-grid .public-form .form-grid-2,
.public-form.contact-form .form-grid-2 {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(22px, 2.4vw, 32px) !important;
}

.contact-card .form-group,
.contact-grid .form-group,
.public-form.contact-form .form-group {
  margin-bottom: 0 !important;
}

.contact-card label,
.contact-grid label,
.public-form.contact-form label {
  margin-bottom: 10px !important;
  line-height: 1.2 !important;
}

.contact-card input,
.contact-card select,
.contact-card textarea,
.contact-grid input,
.contact-grid select,
.contact-grid textarea,
.public-form.contact-form input,
.public-form.contact-form select,
.public-form.contact-form textarea {
  min-height: 58px !important;
  padding: 15px 18px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}

.contact-card textarea,
.contact-grid textarea,
.public-form.contact-form textarea {
  min-height: 170px !important;
}

.contact-card button[type="submit"],
.contact-grid button[type="submit"],
.public-form.contact-form button[type="submit"] {
  min-height: 58px !important;
  margin-top: clamp(12px, 1.8vw, 24px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
}

.faq-section,
section:has(.faq-list) {
  padding-top: clamp(88px, 8vw, 130px) !important;
  padding-bottom: clamp(88px, 8vw, 130px) !important;
}

@media (max-width: 1024px) {
  .contact-section,
  section:has(.contact-grid) {
    padding-top: 76px !important;
    padding-bottom: 76px !important;
  }

  .contact-grid {
    width: min(100% - 40px, 760px) !important;
    grid-template-columns: 1fr !important;
    gap: 44px !important;
    align-items: stretch !important;
  }

  .contact-card {
    padding: 34px !important;
  }
}

@media (max-width: 640px) {
  .contact-section,
  section:has(.contact-grid) {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }

  .contact-grid {
    width: min(100% - 28px, 760px) !important;
    gap: 32px !important;
  }

  .contact-card {
    padding: 24px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }

  .contact-card .public-form .form-grid-2,
  .contact-grid .public-form .form-grid-2,
  .public-form.contact-form .form-grid-2 {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .contact-card input,
  .contact-card select,
  .contact-card textarea,
  .contact-grid input,
  .contact-grid select,
  .contact-grid textarea,
  .public-form.contact-form input,
  .public-form.contact-form select,
  .public-form.contact-form textarea {
    min-height: 52px !important;
    padding: 13px 15px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }

  .contact-card textarea,
  .contact-grid textarea,
  .public-form.contact-form textarea {
    min-height: 140px !important;
  }
}



/* ===============================================
   MOBILE + DASHBOARD FINAL FIX PATCH
   Applies checkbox styling, mobile nav cleanup,
   admin topbar/sidebar responsiveness, tables, and panel polish.
   =============================================== */

/* -- Dashboard checkbox -> custom toggle -- */
.admin-main input[type="checkbox"],
.admin-panel input[type="checkbox"],
.admin-page input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
  border: 2px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  transition: background .15s, border-color .15s, box-shadow .15s;
  flex-shrink: 0;
  vertical-align: middle;
  padding: 0;
  margin: 0;
}
.admin-main input[type="checkbox"]:checked,
.admin-panel input[type="checkbox"]:checked,
.admin-page input[type="checkbox"]:checked {
  background: var(--primary);
  border-color: var(--primary);
}
.admin-main input[type="checkbox"]:checked::after,
.admin-panel input[type="checkbox"]:checked::after,
.admin-page input[type="checkbox"]:checked::after {
  content: '';
  width: 11px;
  height: 7px;
  border-left: 2.5px solid #fff;
  border-bottom: 2.5px solid #fff;
  transform: rotate(-45deg) translateY(-1px);
  display: block;
}
.admin-main input[type="checkbox"]:focus-visible,
.admin-panel input[type="checkbox"]:focus-visible,
.admin-page input[type="checkbox"]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(29,185,84,.25);
  border-color: var(--primary);
}

/* -- Inline checkbox label row -- */
.check-row,
.admin-check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  color: var(--text-dark);
}
.check-row label,
.admin-check-row label {
  cursor: pointer;
  font-weight: 500;
  margin: 0;
}

/* -- Dashboard input height override -- */
.admin-main input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]),
.admin-main select,
.admin-panel input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]),
.admin-panel select,
.admin-panel-body input,
.admin-panel-body select,
.admin-panel-body textarea {
  min-height: 40px;
  padding: 8px 12px;
  font-size: 14px;
}
.admin-main textarea,
.admin-panel textarea {
  min-height: 100px;
}

/* -- Dashboard radio buttons -- */
.admin-main input[type="radio"],
.admin-panel input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: 18px;
  border: 2px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  padding: 0;
  margin: 0;
  vertical-align: middle;
  flex-shrink: 0;
}
.admin-main input[type="radio"]:checked,
.admin-panel input[type="radio"]:checked {
  border-color: var(--primary);
}
.admin-main input[type="radio"]:checked::after,
.admin-panel input[type="radio"]:checked::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary);
  display: block;
}

/* -- Announce bar -- */
.announce-bar { position: relative; z-index: 201; }
.announce-bar-close:hover {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-radius: var(--inrep-radius, 10px) !important;
}

/* -- Public nav stability -- */
.mkt-nav {
  min-width: 0;
}
.mkt-nav-logo {
  white-space: nowrap;
  text-decoration: none;
  flex-shrink: 0;
}
.mkt-nav-logo .inrep-mark { flex: 0 0 auto; }
.mkt-nav-logo > span:not(.inrep-mark) {
  display: inline;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mkt-nav-item:hover,
.mkt-nav-menu-btn:hover {
  background: var(--bg-light);
  color: var(--text-dark);
  text-decoration: none;
}
.mkt-nav-item[aria-current="page"] {
  color: var(--primary);
  font-weight: 600;
}
.mkt-dropdown {
  min-width: 220px;
  max-width: min(340px, calc(100vw - 32px));
}
.mkt-dropdown a strong {
  display: block;
  font-size: 14px;
  font-weight: 650;
  color: var(--text-dark);
  margin-bottom: 2px;
}
.mkt-dropdown a small {
  font-size: 12px;
  color: var(--text-muted-dark);
  display: block;
}
.mkt-nav-signup,
.mkt-nav-actions .btn.dark,
.mkt-nav-actions a[href*="register"] {
  white-space: nowrap;
  flex-shrink: 0;
}
.mkt-nav-search { max-width: 220px; }
@media (max-width: 1200px) { .mkt-nav-search { max-width: 160px; } }
@media (max-width: 1100px) { .mkt-nav-search { display: none !important; } }

.mkt-nav-toggle {
  display: none;
  width: 40px;
  height: 40px;
  border: 1.5px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: var(--text-dark);
  place-items: center;
  flex-shrink: 0;
  cursor: pointer;
}
.mkt-nav-toggle svg {
  width: 18px;
  height: 18px;
  display: block;
}

/* -- Public mobile nav drawer refinements -- */
.mkt-mobile-drawer {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.mkt-mobile-drawer-head {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-light);
  margin-bottom: 14px;
  flex-shrink: 0;
}
.mkt-mobile-search {
  flex-shrink: 0;
  margin-bottom: 12px;
}
.mkt-mobile-links {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: 24px;
}
.mkt-mobile-links a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--inrep-radius, 10px) !important;
  font-weight: 600;
  font-size: 15px;
  color: var(--text-dark);
  text-decoration: none;
}
.mkt-mobile-links a:hover { background: var(--bg-light); }
.mkt-mobile-links a[aria-current="page"] {
  background: var(--primary-soft);
  color: var(--primary-dark);
}
.mkt-mobile-links .nav-section-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-muted-dark);
  font-weight: 700;
  padding: 12px 14px 4px;
  pointer-events: none;
}
.mkt-mobile-footer {
  flex-shrink: 0;
  border-top: 1px solid var(--border-light);
  padding-top: 14px;
  display: flex;
  gap: 8px;
}
.mkt-mobile-footer a,
.mkt-mobile-footer button {
  flex: 1;
  text-align: center;
  padding: 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  font-weight: 650;
  font-size: 14px;
  border: 1.5px solid var(--border-light);
  color: var(--text-dark);
  background: #fff;
}
.mkt-mobile-footer a.primary,
.mkt-mobile-footer button.primary {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

@media (max-width: 1024px) {
  .mkt-nav {
    height: 64px;
    padding: 0 20px;
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
  .mkt-nav-toggle { display: inline-grid !important; justify-self: end; }
  .mkt-nav-items { display: none !important; }
  .mkt-nav-actions .mkt-nav-signin { display: none; }
  .mkt-nav-actions .mkt-nav-signup { display: inline-flex; }
}
@media (max-width: 600px) {
  .mkt-nav-actions .mkt-nav-signup { display: none; }
  .mkt-nav { height: 58px; padding: 0 16px; gap: 10px; }
}

/* -- Admin shell safety -- */
.admin-shell {
  min-width: 0;
}
.admin-main {
  min-width: 0;
}

/* -- Topbar mobile: reduce to essentials -- */
@media (max-width: 1023px) {
  .admin-topbar {
    padding: 0 12px;
    gap: 8px;
    min-width: 0;
  }
  .admin-topbar-action-labeled,
  .admin-topbar-actions > a.admin-icon-btn:not(.admin-topbar-action-labeled),
  .admin-logout-form {
    display: none !important;
  }
  .admin-topbar .mkt-nav-logo {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    color: var(--text-dark);
    font-family: var(--font-display);
    flex-shrink: 0;
  }
  .admin-topbar .mkt-nav-logo span:not(.inrep-mark) {
    display: none;
  }
  .admin-topbar-title {
    flex: 1 1 auto;
    min-width: 0;
    max-width: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 15px;
  }
  .admin-search {
    display: none !important;
  }
  .admin-mobile-search-btn {
    display: inline-flex !important;
    width: 38px;
    height: 38px;
    border: 1px solid var(--border-light);
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .admin-mobile-search-btn svg {
    width: 16px !important;
    height: 16px !important;
  }
  .admin-topbar-actions {
    margin-left: auto;
    gap: 6px;
    flex-shrink: 0;
  }
  .admin-profile-menu,
  .admin-profile-trigger,
  .admin-avatar {
    flex-shrink: 0;
  }
}
@media (max-width: 520px) {
  .admin-topbar-title { font-size: 14px; }
  .admin-topbar .mkt-nav-logo { display: inline-flex; }
  .admin-topbar-menu { flex-shrink: 0; }
}
@media (max-width: 380px) {
  .admin-topbar .mkt-nav-logo { display: none; }
}
.admin-profile-popover-edit.danger {
  background: #fff5f5;
  border-color: #fca5a5;
  color: #b91c1c;
}
.admin-profile-popover-edit.danger:hover { background: #fee2e2; }

/* -- Mobile sidebar: force content visible and scrollable -- */
@media (max-width: 1023px) {
  .admin-sidebar {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(320px, 86vw) !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    display: block !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transform: translateX(-105%) !important;
    transition: transform .22s ease !important;
    z-index: 220 !important;
    box-shadow: 24px 0 80px rgba(0,0,0,.28);
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.22) transparent;
  }
  body.admin-sidebar-open .admin-sidebar {
    transform: translateX(0) !important;
  }
  .admin-sidebar-header {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--admin-sidebar-bg);
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 14px 14px 12px;
    border-bottom: 1px solid rgba(255,255,255,.1);
    margin-bottom: 8px;
  }
  .admin-sidebar > nav,
  .admin-sidebar > .admin-sidebar-section,
  .admin-sidebar-sections-wrap {
    flex: none !important;
    overflow: visible !important;
    padding-bottom: 0;
  }
  body.admin-sidebar-open .admin-sidebar-brand span:not(.inrep-mark),
  body.admin-sidebar-open.admin-sidebar-collapsed .admin-sidebar-brand span:not(.inrep-mark) {
    display: inline !important;
  }
  body.admin-sidebar-open .admin-sidebar-label,
  body.admin-sidebar-open.admin-sidebar-collapsed .admin-sidebar-label {
    display: flex !important;
  }
  body.admin-sidebar-open .admin-sidebar-link,
  body.admin-sidebar-open.admin-sidebar-collapsed .admin-sidebar-link {
    width: 100% !important;
    justify-content: flex-start !important;
    padding: 0 12px !important;
  }
  body.admin-sidebar-open .admin-sidebar-link span,
  body.admin-sidebar-open.admin-sidebar-collapsed .admin-sidebar-link span {
    display: inline !important;
  }
  body.admin-sidebar-open .admin-sidebar-links {
    display: grid !important;
  }
  .admin-sidebar-section {
    display: grid !important;
  }
  .admin-sidebar-section[hidden],
  .admin-sidebar-pinned[hidden],
  .admin-sidebar-recent[hidden] {
    display: none !important;
  }
  .admin-sidebar-close {
    display: inline-grid !important;
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255,255,255,.15);
    border-radius: var(--inrep-radius, 10px) !important;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.7);
    place-items: center;
    flex-shrink: 0;
  }
  .admin-sidebar-close:hover {
    background: rgba(255,255,255,.15);
    color: #fff;
  }
  .admin-sidebar-close svg {
    width: 16px !important;
    height: 16px !important;
  }
  .admin-sidebar-collapse-toggle {
    display: none !important;
  }
  .admin-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 210;
    background: rgba(10,31,21,.45);
    backdrop-filter: blur(2px);
  }
  body.admin-sidebar-open .admin-sidebar-overlay {
    display: block !important;
  }
}

/* -- Admin table refinement -- */
.admin-table-wrap { overflow-x: auto; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.admin-table th {
  background: var(--bg-light);
  color: var(--text-muted-dark);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 10px 14px;
  border-bottom: 2px solid var(--border-light);
  white-space: nowrap;
  text-align: left;
  position: sticky;
  top: 0;
  z-index: 1;
}
.admin-table td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--border-light);
  color: var(--text-dark);
  vertical-align: middle;
}
.admin-table tbody tr:hover td { background: #f9fdf9; }
.admin-table tbody tr:last-child td { border-bottom: 0; }
.admin-table .cell-mono {
  font-family: 'Courier New', monospace;
  font-size: 12px;
  color: var(--text-muted-dark);
}
.admin-table .cell-action { white-space: nowrap; text-align: right; }
.admin-table .cell-badge { white-space: nowrap; }

/* -- Panel head button: no wrapping -- */
.panel-head .btn,
.panel-head a.btn,
.panel-head button {
  white-space: nowrap;
  flex-shrink: 0;
}
.panel-head {
  flex-wrap: nowrap;
  align-items: center;
}

/* -- Notification preferences form -- */
.notif-pref-row,
.notification-pref-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-light);
}
.notif-pref-row:last-child,
.notification-pref-item:last-child { border-bottom: 0; }
.notif-pref-row label,
.notification-pref-item label {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-dark);
  cursor: pointer;
  margin: 0;
  flex: 1;
}
.notif-pref-row strong,
.notification-pref-item strong {
  display: block;
  color: var(--text-dark);
}
.notif-pref-row small,
.notification-pref-item small {
  display: block;
  font-size: 13px;
  color: var(--text-muted-dark);
  font-weight: 400;
  margin-top: 2px;
}
.admin-panel-body > label {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border-light);
  cursor: pointer;
  margin: 0;
}
.admin-panel-body > label:last-of-type { border-bottom: 0; }

/* -- Admin page header -- */
.admin-page-header {
  align-items: flex-start;
  flex-wrap: wrap;
}
.admin-page-header > div:first-child {
  flex: 1;
  min-width: 200px;
}
.admin-page-header .admin-actions {
  flex-shrink: 0;
}

/* -- Breadcrumbs -- */
.admin-breadcrumbs {
  flex-wrap: wrap;
  gap: 4px 8px;
}
.admin-breadcrumbs span[aria-hidden="true"] { color: var(--text-muted-dark); }

/* -- Empty state -- */
.empty-state {
  text-align: center;
  padding: 48px 24px;
  color: var(--text-muted-dark);
}
.empty-state h3 {
  font-size: 16px;
  color: var(--text-dark);
  margin: 0 0 8px;
}
.empty-state p {
  font-size: 14px;
  margin: 0 0 16px;
}

/* -- Status/health items in dashboard -- */
.health-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 16px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
}
.health-item-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-dark);
}
.health-item-detail {
  font-size: 13px;
  color: var(--text-muted-dark);
  margin-top: 2px;
}
.health-item-status {
  font-size: 12px;
  font-weight: 700;
}
.health-item-status.ok { color: var(--primary-dark); }
.health-item-status.warn { color: #92400e; }
.health-item-status.error { color: #b91c1c; }
.health-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  flex-shrink: 0;
  background: var(--border-light);
}
.health-dot.ok {
  background: var(--primary);
  box-shadow: 0 0 0 3px rgba(29,185,84,.2);
}
.health-dot.warn {
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245,158,11,.2);
}
.health-dot.error {
  background: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.2);
}

/* -- Score bar -- */
.score-bar-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}
.score-bar {
  flex: 1;
  height: 8px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--border-light);
  overflow: hidden;
}
.score-bar-fill {
  height: 100%;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary);
  transition: width .4s ease;
}
.score-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-dark);
  min-width: 36px;
  text-align: right;
}

/* -- Dashboard panel and form polish -- */
.admin-panel {
  overflow: hidden;
}
.admin-panel > h2:first-child {
  margin: 0;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-light);
  font-size: 18px;
  line-height: 1.2;
}
.admin-panel > form,
.admin-panel > .form-grid {
  padding: 20px;
}
.admin-panel .form-grid {
  gap: 16px;
}
.admin-panel .full {
  grid-column: 1 / -1;
}
.admin-grid {
  align-items: start;
}
.admin-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 900px) {
  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4,
  .admin-grid-5 {
    grid-template-columns: 1fr !important;
  }
  .panel-head {
    align-items: flex-start;
    flex-wrap: wrap;
  }
}
@media (max-width: 560px) {
  .admin-panel > h2:first-child,
  .admin-panel > form,
  .admin-panel > .form-grid {
    padding-left: 16px;
    padding-right: 16px;
  }
  .notif-pref-row,
  .notification-pref-item {
    padding-left: 0;
    padding-right: 0;
  }
}

/* ===============================================
   SCREENSHOT CSS REPAIR PATCH - 2026-05-06
   Fixes the image-reported spacing, alignment, visibility, nav fallback,
   public search filter layout, hero search layout, feature-flow cards,
   docs/help panel spacing, footer mark, and dashboard topbar/sidebar polish.
   =============================================== */

:root {
  --public-section-y: clamp(64px, 7vw, 104px);
  --public-section-gap: clamp(28px, 4vw, 56px);
}

/* Public nav: Get Started must have a real href fallback and stay visible/clickable. */
.mkt-nav-actions .mkt-nav-signup,
.mkt-mobile-footer .mkt-nav-signup,
.mkt-mobile-footer .btn.primary {
  text-decoration: none !important;
  white-space: nowrap !important;
  cursor: pointer;
}

/* Home hero search: keep the search button inside the input row on desktop. */
.hero-search,
.mkt-hero .hero-search {
  width: min(760px, 100%);
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 8px;
  margin: 26px 0 18px;
  background: #fff;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.18);
}
.hero-search input {
  flex: 1 1 auto;
  min-width: 0;
  width: auto !important;
  min-height: 50px;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--text-dark) !important;
  padding: 0 16px !important;
}
.hero-search .btn-hero-primary,
.hero-search button {
  flex: 0 0 auto;
  min-height: 50px;
  padding-inline: 28px;
  border-radius: var(--inrep-radius, 10px) !important;
}
.hero-trust-row {
  gap: 10px 14px !important;
  line-height: 1.4;
}
.hero-trust-row span {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

/* Dark showcase sections: remove accidental white gaps and keep content above arcs. */
.feature-showcase {
  margin: 0 !important;
  padding: clamp(80px, 8vw, 128px) 0 !important;
  background: var(--bg-dark) !important;
  color: var(--text-light) !important;
}
.feature-showcase + .feature-showcase {
  border-top: 1px solid rgba(255,255,255,.06);
}
.feature-showcase-grid {
  width: min(1200px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
  align-items: center !important;
  gap: clamp(48px, 7vw, 96px) !important;
}
.feature-showcase-h2 {
  color: #fff !important;
  max-width: 680px;
}
.feature-showcase-desc {
  color: rgba(240,247,240,.88) !important;
  max-width: 680px;
}
.feature-showcase-link {
  color: var(--accent-green) !important;
}
.feature-showcase-link:hover {
  color: #fff !important;
}
.feature-showcase::before,
.feature-showcase::after,
.final-cta::before,
.final-cta::after {
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .32 !important;
}
.feature-showcase-grid,
.feature-showcase-grid > *,
.final-cta > * {
  position: relative !important;
  z-index: 2 !important;
}

/* Fix the concatenated UploadValidateReviewPublishReport visual. */
.feature-flow-card {
  width: min(520px, 100%);
  margin-inline: auto;
  display: grid !important;
  gap: 14px !important;
  padding: clamp(28px, 4vw, 44px) !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.18) !important;
  color: var(--text-dark) !important;
}
.feature-flow-card span {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 12px 18px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
  color: var(--text-dark) !important;
  font-weight: 750;
  line-height: 1.2;
  white-space: normal !important;
}

/* White cards used inside dark showcases must not inherit white text. */
.checklist-card,
.readiness-card,
.access-mode-card,
.feature-flow-card {
  position: relative !important;
  z-index: 3 !important;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.checklist-card *,
.readiness-card *,
.access-mode-card *,
.feature-flow-card * {
  opacity: 1 !important;
}
.readiness-card {
  width: min(520px, 100%);
  margin-inline: auto;
  padding: clamp(28px, 4vw, 40px) !important;
  gap: 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: var(--text-dark) !important;
}
.readiness-card span {
  color: var(--text-dark) !important;
  font-weight: 650;
  min-height: 50px;
}
.access-mode-card span {
  text-align: left !important;
  justify-content: flex-start !important;
  min-height: 64px;
  color: var(--text-dark) !important;
  background: #fff !important;
}
.checklist-card {
  width: min(520px, 100%);
  margin-inline: auto;
}
.checklist-item span:last-child,
.checklist-card li,
.checklist-card b,
.checklist-card strong {
  color: var(--text-dark) !important;
}
.checklist-dot::after {
  content: '' !important;
  display: block !important;
}

/* Final CTA blocks: reduce excessive white gaps while keeping breathing room. */
.final-cta {
  width: min(1200px, calc(100% - 48px)) !important;
  margin: clamp(48px, 5vw, 76px) auto !important;
  padding: clamp(72px, 8vw, 116px) clamp(28px, 5vw, 64px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: #fff !important;
}
.final-cta h1,
.final-cta h2,
.final-cta h3,
.final-cta p,
.final-cta a,
.final-cta button {
  position: relative !important;
  z-index: 2 !important;
}
.final-cta p {
  color: rgba(240,247,240,.9) !important;
}
.final-cta .btn-hero-primary,
.final-cta .btn-primary,
.final-cta .btn.primary {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
}

/* Public cards sections: consistent spacing without huge accidental empty areas. */
.cards-section {
  padding-top: var(--public-section-y) !important;
  padding-bottom: var(--public-section-y) !important;
}
.page-hero,
.docs-hero {
  padding-top: clamp(72px, 8vw, 112px) !important;
  padding-bottom: clamp(56px, 6vw, 88px) !important;
}
.page-hero + .cards-section,
.docs-hero + .cards-section,
.page-hero + .repository-browser,
.docs-hero + .docs-grid-section {
  padding-top: clamp(48px, 5vw, 72px) !important;
}

/* Public national search filter: use one standard search card instead of a stacked admin form. */
.mkt-page .admin-filter-bar {
  width: min(1120px, 100%);
  display: grid !important;
  grid-template-columns: minmax(260px, 2fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(110px, .75fr) auto;
  gap: 14px !important;
  align-items: end !important;
  padding: 18px !important;
  margin: 0 auto clamp(28px, 3vw, 42px) !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 18px 52px rgba(10,31,21,.08) !important;
}
.mkt-page .admin-filter-bar label {
  display: grid !important;
  gap: 7px !important;
  margin: 0 !important;
  color: var(--text-dark) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
.mkt-page .admin-filter-bar input,
.mkt-page .admin-filter-bar select {
  min-height: 48px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 10px 14px !important;
  font-weight: 500;
}
.mkt-page .admin-filter-bar .btn,
.mkt-page .admin-filter-bar button {
  min-height: 48px !important;
  padding-inline: 24px !important;
  white-space: nowrap !important;
}
.mkt-page .admin-filter-bar + .repository-grid {
  width: min(1120px, 100%) !important;
  min-height: 180px;
  align-items: center;
}
.repository-grid > .empty-state,
.projects-public-grid > .empty-state {
  grid-column: 1 / -1;
  width: 100%;
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
}

/* Search preview block: repair invisible rows and restore card spacing. */
.search-preview-section,
.search-preview-section.container {
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr) !important;
  gap: clamp(32px, 6vw, 72px) !important;
  align-items: center !important;
  width: min(1200px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
  padding: 0 !important;
  color: var(--text-dark) !important;
}
.search-preview-card,
.search-preview-card * {
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.search-preview-card {
  min-height: 260px;
  padding: 28px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.search-preview-row {
  padding: 16px 0 !important;
}
.search-preview-row span,
.search-preview-bar {
  color: var(--text-muted-dark) !important;
}

/* Docs helper panel: remove the huge empty box height. */
.help-panel,
main > section.help-panel {
  min-height: 0 !important;
  width: min(1100px, calc(100% - 48px)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  padding: clamp(30px, 4vw, 48px) !important;
  margin: clamp(48px, 5vw, 72px) auto !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: none !important;
}
.help-panel h2,
.help-panel p {
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.help-panel h2 { margin-bottom: 10px !important; }
.help-panel p { margin-bottom: 0 !important; }
.help-panel .btn { flex-shrink: 0; }

/* Contact form/other two-column public forms: use proper grid and inner spacing. */
.form-row-2 {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2.2vw, 28px) !important;
}
.contact-section {
  padding-top: clamp(88px, 8vw, 132px) !important;
  padding-bottom: clamp(88px, 8vw, 132px) !important;
}
.contact-grid .public-form {
  gap: clamp(20px, 2.4vw, 30px) !important;
}

/* Footer brand mark: make it a proper square logo, not a thin green strip. */
.mkt-footer-logo .inrep-mark,
.mkt-footer .inrep-mark {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  display: inline-grid !important;
  place-items: center !important;
  background: linear-gradient(135deg, var(--primary), #0f5f3e) !important;
  color: #fff !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}

/* Dashboard topbar/sidebar: keep the topbar search in the topbar and avoid overlay-looking layout. */
.admin-topbar {
  min-width: 0 !important;
  overflow: visible !important;
}
.admin-search {
  position: relative !important;
  z-index: 1;
  flex: 0 1 380px !important;
  max-width: 380px !important;
  min-width: 180px !important;
}
.admin-sidebar {
  z-index: 120 !important;
}
.admin-sidebar-header {
  gap: 10px !important;
}
.admin-sidebar-label span[aria-hidden="true"] {
  margin-left: 4px;
  opacity: .65;
  font-size: 11px;
}
body.admin-sidebar-collapsed .admin-sidebar-label span[aria-hidden="true"] {
  display: none !important;
}

/* Mobile and tablet tightening. */
@media (max-width: 1024px) {
  .feature-showcase-grid,
  .search-preview-section,
  .search-preview-section.container {
    grid-template-columns: 1fr !important;
  }
  .mkt-page .admin-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .mkt-page .admin-filter-bar label:first-child {
    grid-column: 1 / -1;
  }
  .mkt-page .admin-filter-bar button {
    justify-self: start;
  }
}
@media (max-width: 768px) {
  .hero-search,
  .mkt-hero .hero-search {
    display: grid !important;
    gap: 10px;
    padding: 10px;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .hero-search input,
  .hero-search button,
  .hero-search .btn-hero-primary {
    width: 100% !important;
  }
  .hero-trust-row span {
    white-space: normal;
  }
  .feature-showcase {
    padding: 64px 0 !important;
  }
  .feature-showcase-grid,
  .search-preview-section,
  .search-preview-section.container {
    width: min(100% - 28px, 720px) !important;
  }
  .final-cta {
    width: min(100% - 28px, 760px) !important;
    margin-block: 44px !important;
    padding: 56px 22px !important;
  }
  .final-cta h2,
  .feature-showcase-h2 {
    font-size: clamp(32px, 10vw, 46px) !important;
  }
  .mkt-page .admin-filter-bar {
    grid-template-columns: 1fr !important;
    padding: 16px !important;
  }
  .help-panel,
  main > section.help-panel {
    width: min(100% - 28px, 720px) !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .help-panel .btn {
    width: 100%;
  }
  .form-row-2 {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 520px) {
  .mkt-hero-product {
    transform: none !important;
  }
  .mkt-hero-grid {
    width: min(100% - 28px, 720px) !important;
  }
  .hero-search {
    margin-top: 20px;
  }
  .access-mode-card {
    grid-template-columns: 1fr !important;
  }
}

/* ===============================================
   NAV, REGISTRATION, INSTITUTION PAGE + SPACING FINAL PATCH
   =============================================== */
.mkt-nav{position:sticky!important;top:0!important;z-index:240!important;transition:transform .22s ease,box-shadow .18s ease,background .18s ease!important;will-change:transform}.mkt-nav.nav-hidden{transform:translateY(-100%)!important}.mkt-nav.scrolled{box-shadow:0 10px 34px rgba(10,31,21,.08)!important}.mkt-dropdown a{align-items:flex-start!important;gap:12px!important}.mkt-dropdown a span{display:grid!important;gap:2px!important}
@media (min-width:1024px){.admin-topbar-menu{display:none!important}.admin-sidebar-collapse-toggle{display:inline-grid!important}.admin-sidebar-close{display:none!important}}@media (max-width:1023px){.admin-topbar-menu{display:inline-grid!important}.admin-sidebar-collapse-toggle{display:none!important}.admin-sidebar-close{display:inline-grid!important}}
.admin-sidebar-label{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:8px!important;width:100%!important;min-height:30px!important;padding:8px 10px 6px!important;border:0!important;background:transparent!important;text-align:left!important;line-height:1!important;cursor:pointer!important}.admin-sidebar-label-text{min-width:0!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.admin-sidebar-chevron,.admin-sidebar-label span[aria-hidden="true"]{width:14px!important;height:14px!important;display:inline-grid!important;place-items:center!important;margin:0!important;line-height:1!important;font-size:12px!important;transform-origin:center!important;transition:transform .16s ease,opacity .16s ease!important;flex:0 0 14px!important;opacity:.7!important}.admin-sidebar-section.is-collapsed .admin-sidebar-chevron,.admin-sidebar-section.is-collapsed .admin-sidebar-label span[aria-hidden="true"]{transform:rotate(-90deg)!important}body.admin-sidebar-collapsed .admin-sidebar-label,body.admin-sidebar-collapsed .admin-sidebar-label-text,body.admin-sidebar-collapsed .admin-sidebar-chevron{display:none!important}
.mkt-tight-stats + .cards-section,.mkt-tight-stats + section.cards-section{padding-top:clamp(48px,5vw,72px)!important}.mkt-tight-stats{padding-bottom:clamp(32px,4vw,52px)!important}.cards-section .section-heading,.workflow-section .section-heading,.audience-section .section-heading{margin-bottom:clamp(32px,4vw,48px)!important}
.contact-section,section:has(.contact-grid){padding-top:clamp(64px,6vw,96px)!important;padding-bottom:clamp(64px,6vw,96px)!important}.contact-grid{gap:clamp(42px,5vw,72px)!important;width:min(1180px,calc(100% - 56px))!important}.contact-card{padding:clamp(30px,3.6vw,46px)!important;border-radius:var(--inrep-radius, 10px) !important}.contact-support-grid{margin-top:clamp(26px,3vw,40px)!important}.contact-support-grid div{padding:clamp(18px,2.2vw,28px) 0!important}.contact-card .public-form,.contact-grid .public-form,.public-form.contact-form{gap:clamp(16px,2vw,24px)!important}.contact-card .public-form .form-grid-2,.contact-grid .public-form .form-grid-2,.public-form.contact-form .form-grid-2{gap:clamp(16px,2vw,24px)!important}.contact-card textarea,.contact-grid textarea,.public-form.contact-form textarea{min-height:140px!important}
.auth-body:has(.register-center){align-items:start!important;padding:clamp(28px,4vw,56px) 20px!important;overflow-y:auto!important}.auth-center.register-center{width:min(1040px,calc(100vw - 40px))!important;max-width:1040px!important;padding:clamp(28px,4vw,48px)!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;box-shadow:0 32px 90px rgba(0,0,0,.34)!important;display:grid!important;gap:22px!important}.register-center>.auth-logo{justify-self:center!important;margin:0 0 6px!important}.register-center .signup-intro-card{display:grid!important;gap:12px!important;padding:26px!important;border-radius:var(--inrep-radius, 10px) !important;background:linear-gradient(135deg,var(--bg-dark),#103c28)!important;color:#fff!important}.register-center .signup-intro-card h1,.register-center .signup-intro-card h2{color:#fff!important;font-size:clamp(28px,4vw,42px)!important;line-height:1.08!important;margin:0!important}.register-center .signup-intro-card p{margin:0!important;max-width:760px!important;color:rgba(255,255,255,.76)!important}.signup-switch{display:flex!important;gap:10px!important;flex-wrap:wrap!important;margin-top:8px!important}.signup-switch a{min-height:38px!important;padding:8px 14px!important;border-radius:var(--inrep-radius, 10px) !important;border:1px solid rgba(255,255,255,.24)!important;color:#fff!important;font-weight:700!important}.signup-switch a.active{background:var(--primary)!important;border-color:var(--primary)!important}.register-center form.auth-card.signup-form-grid{width:100%!important;max-width:none!important;min-height:0!important;display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:18px 22px!important;padding:clamp(24px,3.2vw,38px)!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 18px 46px rgba(10,31,21,.10)!important}.register-center .form-section-title{margin-top:10px!important;padding-top:18px!important;border-top:1px solid var(--border-light)!important;color:var(--primary-dark)!important;font-family:var(--font-display)!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:.08em!important;font-size:12px!important}.register-center .form-section-title:first-of-type{margin-top:0!important;padding-top:0!important;border-top:0!important}.register-center label{margin:0!important}.register-center input,.register-center select,.register-center textarea{min-height:52px!important;border-radius:var(--inrep-radius, 10px) !important}.register-center textarea{min-height:130px!important}.register-center .auth-note{background:var(--bg-light)!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;padding:14px 16px!important;margin:4px 0 0!important;color:var(--text-muted-dark)!important}.register-center .small-auth-card{width:100%!important;max-width:none!important;box-shadow:none!important;border:1px solid var(--border-light)!important;padding:16px!important;margin:0!important}@media (max-width:760px){.auth-center.register-center{width:min(100vw - 24px,720px)!important;padding:20px!important}.register-center form.auth-card.signup-form-grid{grid-template-columns:1fr!important;padding:20px!important}.register-center .signup-intro-card{padding:22px!important}}
.institution-page .institution-hero,.institution-hero{text-align:center!important;padding-top:clamp(72px,7vw,120px)!important;padding-bottom:clamp(56px,6vw,88px)!important}.institution-page .institution-hero .hero-search,.institution-hero .hero-search{width:min(760px,calc(100% - 32px))!important;margin:clamp(26px,3vw,36px) auto 0!important;display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:10px!important;align-items:center!important;padding:10px!important;background:#fff!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 18px 46px rgba(10,31,21,.08)!important}.institution-page .institution-hero .hero-search input,.institution-hero .hero-search input{border:0!important;box-shadow:none!important;min-height:46px!important}.institution-page .institution-hero .hero-actions,.institution-hero .hero-actions{display:flex!important;justify-content:center!important;gap:10px!important;flex-wrap:wrap!important}.institution-page .cards-section,.institution-page .section-white,.institution-page .mkt-light{padding-top:clamp(58px,6vw,86px)!important;padding-bottom:clamp(58px,6vw,86px)!important}.institution-page .admin-panel{padding:22px!important}@media (max-width:640px){.institution-page .institution-hero .hero-search,.institution-hero .hero-search{grid-template-columns:1fr!important}.institution-page .institution-hero .hero-search button,.institution-hero .hero-search button{width:100%!important}}
.national-search-form{width:min(1080px,100%)!important;margin:0 auto 26px!important;padding:20px!important;display:grid!important;grid-template-columns:minmax(260px,2fr) minmax(160px,1fr) minmax(160px,1fr) minmax(120px,.7fr) auto!important;gap:14px!important;align-items:end!important;background:#fff!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 16px 44px rgba(10,31,21,.08)!important}.national-search-form label{margin:0!important}.national-search-form button{min-height:46px!important;white-space:nowrap!important}@media (max-width:900px){.national-search-form{grid-template-columns:1fr 1fr!important}.national-search-form label:first-child{grid-column:1/-1!important}}@media (max-width:620px){.national-search-form{grid-template-columns:1fr!important}.national-search-form button{width:100%!important}}
.institution-customizer-page .customizer-grid{align-items:start!important}.widget-check-grid{display:grid!important;gap:12px!important}.widget-check-grid .admin-check-row{padding:12px 14px!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:var(--bg-light)!important}.mkt-mobile-footer .btn,.mkt-mobile-footer a,.mkt-mobile-footer button{text-decoration:none!important}



/* ===============================================
   CROSS-CHECK FINAL UI PATCH
   Fixes the remaining screenshot issues without changing structure:
   sidebar chevrons, duplicate hamburger behavior, public nav, signup form,
   contact spacing, national search, institution search, feature cards,
   docs help panel, footer mark, and dashboard icon sizing.
   =============================================== */

/* Admin sidebar chevrons: aligned, readable, and only visible while expanded */
.admin-sidebar-label {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  min-height: 34px !important;
  padding: 10px 12px 7px !important;
  width: 100% !important;
  background: transparent !important;
  border: 0 !important;
  color: rgba(255,255,255,.50) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .09em !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  text-align: left !important;
}
.admin-sidebar-label-text {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.admin-sidebar-chevron {
  width: 14px !important;
  height: 14px !important;
  flex: 0 0 14px !important;
  display: inline-grid !important;
  place-items: center !important;
  margin: 0 !important;
  color: rgba(255,255,255,.55) !important;
  font-size: 12px !important;
  line-height: 1 !important;
  transform-origin: 50% 50% !important;
  transition: transform .16s ease !important;
}
.admin-sidebar-section.is-collapsed .admin-sidebar-chevron {
  transform: rotate(-90deg) !important;
}
body.admin-sidebar-collapsed .admin-sidebar-label {
  display: none !important;
}

/* Only one hamburger per context:
   desktop = sidebar collapse button, mobile = topbar open button */
@media (min-width: 1024px) {
  .admin-topbar-menu,
  [data-admin-sidebar-toggle] {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
  .admin-sidebar-collapse-toggle,
  [data-sidebar-collapse-toggle] {
    display: inline-grid !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .admin-sidebar-close,
  [data-admin-sidebar-close] {
    display: none !important;
  }
}
@media (max-width: 1023px) {
  .admin-topbar-menu,
  [data-admin-sidebar-toggle] {
    display: inline-grid !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .admin-sidebar-collapse-toggle,
  [data-sidebar-collapse-toggle] {
    display: none !important;
  }
  .admin-sidebar-close,
  [data-admin-sidebar-close] {
    display: inline-grid !important;
  }
}

/* Dashboard icon/search safety */
.admin-sidebar svg,
.admin-topbar svg,
.admin-icon-btn svg,
.admin-topbar-menu svg,
.admin-sidebar-collapse-toggle svg,
.admin-sidebar-close svg {
  width: 18px !important;
  height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  flex: 0 0 18px !important;
}
.admin-search svg,
.mkt-nav-search svg {
  width: 16px !important;
  height: 16px !important;
  flex: 0 0 16px !important;
}
.admin-search {
  overflow: hidden !important;
}
.admin-search input {
  min-width: 0 !important;
}

/* Public nav: sticky reveal with no duplicate nav layout pressure */
.public-body .mkt-nav {
  position: sticky !important;
  top: 0 !important;
  z-index: 260 !important;
  transform: translateY(0);
  transition: transform .22s ease, box-shadow .18s ease, background .18s ease !important;
}
.public-body .mkt-nav.nav-hidden {
  transform: translateY(-100%) !important;
}
.mkt-nav-items {
  min-width: 0 !important;
}
.mkt-nav-actions {
  flex-shrink: 0 !important;
}
.mkt-mobile-footer {
  display: flex !important;
  gap: 10px !important;
}
.mkt-mobile-footer .btn {
  flex: 1 1 0 !important;
  text-decoration: none !important;
}

/* Home: give Platform capabilities breathing room after stats */
.mkt-tight-stats {
  padding-top: clamp(34px, 4vw, 54px) !important;
  padding-bottom: clamp(44px, 5vw, 72px) !important;
}
.mkt-tight-stats + .cards-section {
  padding-top: clamp(76px, 7vw, 112px) !important;
}
.cards-section .section-heading {
  margin-bottom: clamp(38px, 4.4vw, 58px) !important;
}

/* Contact: reduce the over-padding added previously */
.contact-section,
section:has(.contact-grid) {
  padding-top: clamp(46px, 5vw, 72px) !important;
  padding-bottom: clamp(54px, 5vw, 80px) !important;
}
.contact-grid {
  width: min(1120px, calc(100% - 48px)) !important;
  gap: clamp(32px, 4vw, 56px) !important;
  align-items: center !important;
}
.contact-card {
  padding: clamp(26px, 3vw, 40px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.contact-support-grid {
  margin-top: clamp(22px, 2.4vw, 34px) !important;
}
.contact-support-grid div {
  padding: clamp(14px, 1.8vw, 22px) 0 !important;
}
.contact-card .public-form,
.contact-grid .public-form,
.public-form.contact-form {
  gap: 16px !important;
}
.contact-card .public-form .form-grid-2,
.contact-grid .public-form .form-grid-2,
.public-form.contact-form .form-grid-2 {
  gap: 16px !important;
}
.contact-card textarea,
.contact-grid textarea,
.public-form.contact-form textarea {
  min-height: 128px !important;
}

/* Signup/Get started page: login-page-style centered card, but still supports detailed fields */
.auth-body:has(.register-center) {
  min-height: 100dvh !important;
  align-items: start !important;
  justify-items: center !important;
  padding: clamp(28px, 5vw, 64px) 20px !important;
  overflow-y: auto !important;
}
.auth-center.register-center {
  width: min(900px, calc(100vw - 40px)) !important;
  max-width: 900px !important;
  display: grid !important;
  gap: 20px !important;
  padding: clamp(28px, 4vw, 46px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.36) !important;
}
.register-center > .auth-logo {
  justify-self: center !important;
  margin: 0 0 4px !important;
}
.register-center .signup-intro-card {
  border-radius: var(--inrep-radius, 10px) !important;
  padding: clamp(22px, 3vw, 32px) !important;
  background: linear-gradient(135deg, #0a1f15, #103c28) !important;
  display: grid !important;
  gap: 10px !important;
}
.register-center form.auth-card.signup-form-grid {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px 20px !important;
  padding: clamp(24px, 3vw, 36px) !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 18px 44px rgba(10,31,21,.10) !important;
  background: #fff !important;
}
.register-center .span-full,
.register-center .form-section-title,
.register-center .auth-note,
.register-center button[type="submit"] {
  grid-column: 1 / -1 !important;
}
.register-center label {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
}
.register-center input,
.register-center select,
.register-center textarea {
  min-height: 50px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 12px 15px !important;
}
.register-center textarea {
  min-height: 120px !important;
}
.register-center button[type="submit"] {
  min-height: 54px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  margin-top: 4px !important;
}
@media (max-width: 760px) {
  .auth-center.register-center {
    width: min(100vw - 24px, 680px) !important;
    padding: 20px !important;
  }
  .register-center form.auth-card.signup-form-grid {
    grid-template-columns: 1fr !important;
    padding: 20px !important;
  }
}

/* University public page: center search and make the landing section balanced */
.institution-page .institution-hero {
  text-align: center !important;
  display: grid !important;
  justify-items: center !important;
  padding-top: clamp(68px, 7vw, 108px) !important;
  padding-bottom: clamp(50px, 6vw, 76px) !important;
}
.institution-page .institution-hero .hero-h1,
.institution-page .institution-hero .hero-subtitle {
  margin-left: auto !important;
  margin-right: auto !important;
}
.institution-page .institution-search,
.institution-page .institution-hero .hero-search {
  width: min(760px, calc(100% - 32px)) !important;
  margin: clamp(24px, 3vw, 34px) auto 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
}
@media (max-width: 640px) {
  .institution-page .institution-search,
  .institution-page .institution-hero .hero-search {
    grid-template-columns: 1fr !important;
  }
  .institution-page .institution-search button,
  .institution-page .institution-hero .hero-search button {
    width: 100% !important;
  }
}

/* National search: force a proper horizontal search card on desktop */
.national-search-section {
  padding-top: clamp(48px, 5vw, 72px) !important;
}
.national-search-form {
  width: min(1080px, 100%) !important;
  margin: 0 auto clamp(28px, 3vw, 42px) !important;
  padding: 18px !important;
  display: grid !important;
  grid-template-columns: minmax(260px, 2fr) minmax(150px, 1fr) minmax(150px, 1fr) minmax(120px, .75fr) auto !important;
  gap: 14px !important;
  align-items: end !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 16px 44px rgba(10,31,21,.08) !important;
}
.national-search-form label {
  display: grid !important;
  gap: 7px !important;
  margin: 0 !important;
}
.national-search-form input,
.national-search-form select {
  min-height: 46px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.national-search-form button {
  min-height: 46px !important;
  white-space: nowrap !important;
}
.national-search-results .empty-state {
  grid-column: 1 / -1 !important;
  width: min(520px, 100%) !important;
  justify-self: center !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
}
@media (max-width: 900px) {
  .national-search-form {
    grid-template-columns: 1fr 1fr !important;
  }
  .national-search-keyword {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 620px) {
  .national-search-form {
    grid-template-columns: 1fr !important;
  }
  .national-search-form button {
    width: 100% !important;
  }
}

/* Feature dark sections: prevent text/card collapse and remove accidental massive white gaps */
.feature-showcase {
  margin: 0 !important;
  padding: clamp(76px, 8vw, 116px) 0 !important;
  background: var(--bg-dark) !important;
  color: #fff !important;
  overflow: hidden !important;
  position: relative !important;
  isolation: isolate !important;
}
.feature-showcase + .feature-showcase {
  border-top: 1px solid rgba(255,255,255,.06) !important;
}
.feature-showcase-grid {
  width: min(1180px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .9fr) !important;
  align-items: center !important;
  gap: clamp(44px, 7vw, 86px) !important;
  position: relative !important;
  z-index: 2 !important;
}
.feature-showcase-grid > * {
  position: relative !important;
  z-index: 2 !important;
  min-width: 0 !important;
}
.feature-flow-card,
.feature-white-card,
.readiness-card,
.access-mode-card,
.checklist-card {
  width: min(520px, 100%) !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: 14px !important;
  padding: clamp(28px, 4vw, 42px) !important;
  background: #fff !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.18) !important;
  color: var(--text-dark) !important;
  opacity: 1 !important;
}
.feature-flow-card span,
.readiness-card span,
.access-mode-card span,
.checklist-card li,
.checklist-card .checklist-item {
  display: flex !important;
  align-items: center !important;
  min-height: 50px !important;
  padding: 12px 18px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
  color: var(--text-dark) !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  white-space: normal !important;
  opacity: 1 !important;
}
.access-mode-card {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
@media (max-width: 900px) {
  .feature-showcase-grid {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 560px) {
  .feature-showcase-grid {
    width: min(100% - 28px, 680px) !important;
  }
  .access-mode-card {
    grid-template-columns: 1fr !important;
  }
}

/* CTA dark rounded blocks: content over decoration, no hidden button/text */
.final-cta {
  position: relative !important;
  isolation: isolate !important;
  overflow: hidden !important;
  margin: clamp(42px, 5vw, 66px) auto !important;
  padding: clamp(62px, 7vw, 96px) clamp(24px, 5vw, 60px) !important;
  width: min(1180px, calc(100% - 48px)) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-dark) !important;
  color: #fff !important;
}
.final-cta > *,
.final-cta h2,
.final-cta p,
.final-cta a,
.final-cta button {
  position: relative !important;
  z-index: 3 !important;
  opacity: 1 !important;
}
.final-cta::before,
.final-cta::after,
.feature-showcase::before,
.feature-showcase::after {
  z-index: 0 !important;
  opacity: .28 !important;
  pointer-events: none !important;
}

/* Docs help panel: remove giant empty height */
.docs-help-panel,
.help-panel {
  min-height: 0 !important;
  padding: clamp(24px, 3vw, 36px) !important;
  margin: clamp(36px, 5vw, 60px) auto clamp(54px, 6vw, 82px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 24px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.docs-help-panel h2,
.help-panel h2 {
  margin-bottom: 10px !important;
}
.docs-help-panel p,
.help-panel p {
  margin: 0 !important;
}
@media (max-width: 720px) {
  .docs-help-panel,
  .help-panel {
    align-items: stretch !important;
    flex-direction: column !important;
  }
}

/* Footer brand mark: stop the /i logo from stretching */
.mkt-footer-logo .inrep-mark,
.mkt-nav-logo .inrep-mark,
.auth-logo .inrep-mark,
.admin-sidebar-brand .inrep-mark {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  min-height: 34px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  display: inline-grid !important;
  place-items: center !important;
  line-height: 1 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}
.mkt-footer-logo .inrep-mark {
  background: var(--primary) !important;
  color: #fff !important;
}

/* Homepage hero search desktop: keep button inside the pill */
.mkt-hero .hero-search {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  width: min(760px, 100%) !important;
}
@media (max-width: 620px) {
  .mkt-hero .hero-search {
    grid-template-columns: 1fr !important;
  }
  .mkt-hero .hero-search button {
    width: 100% !important;
  }
}



/* ===============================================
   MOBILE ADMIN NAV OVERLAY FIX
   Remove the blurred/washed overlay when the dashboard sidebar is open.
   Keep a normal light dim layer only, and keep the sidebar sharp.
   =============================================== */
@media (max-width: 1023px) {
  body.admin-sidebar-open,
  body.admin-sidebar-open .admin-shell,
  body.admin-sidebar-open .admin-main,
  body.admin-sidebar-open .admin-content,
  body.admin-sidebar-open .admin-topbar {
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  .admin-sidebar,
  body.admin-sidebar-open .admin-sidebar {
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    opacity: 1 !important;
    z-index: 300 !important;
  }

  .admin-sidebar-overlay,
  body.admin-sidebar-open .admin-sidebar-overlay {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    background: rgba(10, 31, 21, .28) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    filter: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    z-index: 240 !important;
  }

  body:not(.admin-sidebar-open) .admin-sidebar-overlay {
    opacity: 0 !important;
    pointer-events: none !important;
  }
}

/* ===============================================
   PRICING, DOCS, PAYMENTS, TABLES + SIDEBAR FINAL PATCH
   =============================================== */
.pricing-hero .page-hero-sub{max-width:760px}.pricing-currency-note{margin:18px auto 0;display:inline-flex;padding:9px 14px;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:#fff;color:var(--muted);font-weight:650}.pricing-page-section{padding:70px 0;background:var(--bg-light)}.pricing-toggle-row{display:flex;justify-content:center;gap:8px;margin:0 auto 28px}.pricing-cycle-btn{min-height:40px;padding:8px 18px;border-radius:var(--inrep-radius, 10px) !important;border:1px solid var(--border-light);background:#fff;font-weight:800}.pricing-cycle-btn.is-active{background:var(--bg-dark);color:#fff;border-color:var(--bg-dark)}.pricing-tier-grid{width:min(1180px,calc(100% - 48px));margin:auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.pricing-tier-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:20px}.pricing-tier-card.is-featured{border-color:var(--primary);box-shadow:0 24px 70px rgba(29,185,84,.18)}.pricing-tier-head h2{font-size:24px;margin:14px 0 10px}.pricing-tier-head p{color:var(--muted);margin:0}.pricing-tier-price strong{font-family:var(--font-display);font-size:42px;letter-spacing:-.04em}.pricing-tier-price span{font-weight:800;color:var(--muted)}.pricing-tier-price small{display:block;color:var(--primary-dark);margin-top:8px;font-weight:700}.pricing-feature-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;flex:1}.pricing-feature-list li{position:relative;padding-left:26px;color:var(--text-dark);line-height:1.45}.pricing-feature-list li:before{content:'\2713';position:absolute;left:0;top:0;color:var(--primary);font-weight:900}.pricing-compare-section{padding:74px 0;background:#fff}.pricing-compare-table{width:min(1080px,calc(100% - 48px));margin:auto;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:#fff;box-shadow:var(--shadow);overflow:auto}.docs-article-section{width:min(1120px,calc(100% - 48px));margin:0 auto;padding:70px 0;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px}.docs-article-card,.docs-related-card{background:#fff;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;box-shadow:var(--shadow);padding:32px}.docs-step-list,.docs-note-list{display:grid;gap:14px;line-height:1.65}.docs-step-list li::marker{font-weight:900;color:var(--primary)}.docs-note-list li::marker{color:var(--primary)}.docs-article-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.docs-related-card{align-self:start;position:sticky;top:92px}.docs-related-card a{display:block;padding:14px 0;border-bottom:1px solid var(--border-light);font-weight:800}.docs-related-card a:last-child{border-bottom:0}.docs-related-card span{display:block;color:var(--muted);font-weight:500;margin-top:4px;font-size:13px}.admin-plan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-bottom:22px}.subscription-plan{padding:22px!important;display:flex;flex-direction:column;gap:14px}.subscription-plan.is-featured{border-color:var(--primary)!important;box-shadow:0 22px 58px rgba(29,185,84,.16)!important}.subscription-plan-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.subscription-plan h2{font-size:20px;margin:0}.subscription-plan p{color:var(--muted);margin:0}.subscription-plan ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}.subscription-plan li{position:relative;padding-left:22px;color:var(--text-dark);font-size:14px}.subscription-plan li:before{content:'\2713';position:absolute;left:0;color:var(--primary);font-weight:900}.subscription-price{font-family:var(--font-display);font-size:34px;font-weight:900;color:var(--text-dark);letter-spacing:-.035em}.subscription-price small{font-family:var(--font-body);font-size:13px;color:var(--muted);margin-left:4px}.subscription-choice-form{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:auto}.subscription-choice-form button{grid-column:1/-1}.payment-settings-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.webhook-url-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.webhook-url-grid div{border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:var(--bg-light);padding:14px;min-width:0}.webhook-url-grid code{display:block;white-space:normal;overflow-wrap:anywhere;margin-top:6px;color:var(--primary-dark)}.admin-table-wrap,.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--inrep-radius, 10px) !important}.admin-panel table,.admin-table{min-width:760px;border-collapse:separate!important;border-spacing:0;width:100%;background:#fff}.admin-panel table th,.admin-panel table td,.admin-table th,.admin-table td{padding:14px 16px!important;border-bottom:1px solid var(--border-light)!important;text-align:left!important;vertical-align:middle!important;white-space:normal!important}.admin-panel table th,.admin-table th{background:var(--bg-light)!important;color:var(--muted)!important;font-size:11px!important;text-transform:uppercase!important;letter-spacing:.07em!important;font-weight:900!important;white-space:nowrap!important}.admin-panel table tbody tr:hover td,.admin-table tbody tr:hover td{background:#fbfefb!important}.table-actions,.inline-actions{display:flex!important;flex-wrap:wrap!important;gap:8px!important;align-items:center!important}.table-actions form,.inline-actions form{margin:0!important;display:inline-flex!important}.admin-panel .btn.tiny,.admin-table .btn.tiny{min-height:30px!important;padding:5px 10px!important;border-radius:var(--inrep-radius, 10px) !important;white-space:nowrap!important}.admin-empty-state{padding:34px;border:1px dashed var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:var(--bg-light);display:grid;place-items:center;text-align:center;color:var(--muted)}.admin-empty-state strong{color:var(--text-dark)}
@media(max-width:1023px){body.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-links{display:none!important}body.admin-sidebar-open .admin-sidebar-section:not(.is-collapsed) .admin-sidebar-links{display:grid!important}.admin-sidebar-label{display:flex!important}.admin-sidebar-section.is-collapsed .admin-sidebar-chevron{transform:rotate(-90deg)!important}.pricing-tier-grid,.admin-plan-grid{grid-template-columns:1fr}.docs-article-section{grid-template-columns:1fr}.docs-related-card{position:static}.payment-settings-form,.webhook-url-grid{grid-template-columns:1fr}.subscription-choice-form{grid-template-columns:1fr}.subscription-choice-form button{grid-column:auto}}
@media(max-width:700px){.pricing-tier-grid,.docs-article-section{width:min(100% - 28px,680px)}.pricing-page-section,.pricing-compare-section{padding:46px 0}.pricing-tier-card,.docs-article-card,.docs-related-card{padding:22px}.admin-panel table,.admin-table{min-width:680px}.admin-page-header{gap:14px}.admin-page-header .admin-actions{width:100%}}



/* ===============================================
   DASHBOARD FORMS, TABLES, SEARCHES + SPEED PATCH
   Final dashboard-only cleanup for scattered panels, forms, tables,
   checkboxes, search bars, smart submission assistant, and admin loading.
   =============================================== */
:root {
  --admin-content-max: 1480px;
  --admin-page-gap: 22px;
}

body.admin-fullscreen,
body.admin-fullscreen * {
  text-rendering: optimizeLegibility;
}

.admin-shell {
  contain: layout style;
}

.admin-main {
  width: 100% !important;
  min-width: 0 !important;
  padding: clamp(18px, 2.2vw, 30px) !important;
  background:
    radial-gradient(circle at 88% 0%, rgba(29,185,84,.08), transparent 34%),
    var(--admin-bg) !important;
  overflow: auto !important;
  scroll-behavior: smooth;
}

.admin-main > .admin-breadcrumbs,
.admin-main > .admin-alert,
.admin-main > .admin-page,
.admin-main > .admin-panel,
.admin-main > .admin-grid,
.admin-main > .metric-card,
.admin-main > form,
.admin-main > div:not(.suggest-box) {
  max-width: var(--admin-content-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.admin-page {
  width: 100% !important;
  display: grid !important;
  gap: var(--admin-page-gap) !important;
  min-width: 0 !important;
}

.admin-page-header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin: 0 0 4px !important;
  min-width: 0 !important;
}
.admin-page-header > div {
  min-width: 0 !important;
}
.admin-page-title {
  margin: 0 0 6px !important;
  line-height: 1.08 !important;
  letter-spacing: -.04em !important;
}
.admin-page-subtitle {
  margin: 0 !important;
  color: var(--muted) !important;
  font-size: 15px !important;
  max-width: 920px !important;
}
.admin-page-header .admin-actions,
.admin-page-header form,
.admin-page-header .btn {
  flex: 0 0 auto !important;
}

.admin-grid {
  display: grid !important;
  gap: 18px !important;
  min-width: 0 !important;
}
.admin-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.admin-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.admin-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }

.admin-panel,
form.admin-panel,
.admin-repo-list-card,
.dash-card,
.metric-card {
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 14px 34px rgba(10,31,21,.07) !important;
  overflow: hidden !important;
  min-width: 0 !important;
}

.admin-panel > h2,
.admin-panel > h3,
.admin-panel > .form-section-title,
.admin-panel > .panel-title {
  margin: 0 !important;
  padding: 22px 24px 12px !important;
  font-family: var(--font-display) !important;
  font-size: clamp(17px, 1.5vw, 21px) !important;
  line-height: 1.2 !important;
  letter-spacing: -.025em !important;
  color: var(--text-dark) !important;
}
.admin-panel > h2 + .admin-table-wrap,
.admin-panel > h3 + .admin-table-wrap,
.admin-panel > h2 + .table-responsive,
.admin-panel > h3 + .table-responsive {
  margin-top: 4px !important;
}
.admin-panel > p,
.admin-panel > small,
.admin-panel > .mini-muted,
.admin-panel > .admin-help-list,
.admin-panel > .clean-list,
.admin-panel > .review-list,
.admin-panel > .heatmap-list,
.admin-panel > .tag-cloud,
.admin-panel > .public-tag-cloud,
.admin-panel > .project-status-line,
.admin-panel > .inline-actions,
.admin-panel > .admin-actions,
.admin-panel > .table-row,
.admin-panel > pre,
.admin-panel > code,
.admin-panel > .admin-alert,
.admin-panel > .admin-empty-state,
.admin-panel > .smart-flow,
.admin-panel > .readiness-card,
.admin-panel > .webhook-url-grid,
.admin-panel > .payment-settings-form,
.admin-panel > .subscription-choice-form {
  margin-left: 24px !important;
  margin-right: 24px !important;
}
.admin-panel > p,
.admin-panel > .admin-alert,
.admin-panel > pre,
.admin-panel > .admin-empty-state,
.admin-panel > .admin-help-list,
.admin-panel > .clean-list,
.admin-panel > .review-list,
.admin-panel > .heatmap-list,
.admin-panel > .tag-cloud,
.admin-panel > .public-tag-cloud,
.admin-panel > .readiness-card,
.admin-panel > .webhook-url-grid,
.admin-panel > .payment-settings-form,
.admin-panel > .subscription-choice-form {
  margin-bottom: 24px !important;
}
.admin-panel > pre {
  padding: 16px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f7faf7 !important;
  max-width: calc(100% - 48px) !important;
}

.admin-panel-header,
.panel-head,
.admin-panel > .panel-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 18px 24px !important;
  border-bottom: 1px solid var(--border-light) !important;
  background: linear-gradient(180deg, #fff, #fbfdfb) !important;
}
.admin-panel-body {
  padding: 22px 24px 24px !important;
}

/* Forms: all dashboard forms get sane padding, columns and spacing. */
.admin-main form.form-grid,
.admin-main .form-grid,
form.admin-panel.form-grid,
.admin-panel form.form-grid,
.admin-panel .form-grid,
.admin-filter-bar,
.admin-search-form,
.admin-toolbar-form {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  align-items: end !important;
  min-width: 0 !important;
}
form.admin-panel.form-grid {
  padding: 24px !important;
}
.admin-panel > form.form-grid {
  padding: 0 24px 24px !important;
}
.admin-main label,
.admin-panel label {
  display: grid !important;
  gap: 7px !important;
  align-content: start !important;
  margin: 0 !important;
  min-width: 0 !important;
  color: var(--text-dark) !important;
  font-size: 13px !important;
  font-weight: 750 !important;
}
.admin-main label.full,
.admin-panel label.full,
.admin-main .full,
.admin-panel .full,
.admin-main .span-full,
.admin-panel .span-full,
.admin-main .form-grid > button,
.admin-panel .form-grid > button,
.admin-main .form-section-title,
.admin-panel .form-section-title {
  grid-column: 1 / -1 !important;
}
.admin-main .form-section-title,
.admin-panel .form-section-title {
  padding: 4px 0 2px !important;
  margin: 4px 0 0 !important;
  color: var(--primary-dark) !important;
  font-family: var(--font-display) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.admin-main input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="hidden"]),
.admin-main select,
.admin-main textarea,
.admin-panel input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="hidden"]),
.admin-panel select,
.admin-panel textarea {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 46px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark) !important;
  padding: 10px 13px !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  box-shadow: none !important;
}
.admin-main textarea,
.admin-panel textarea {
  min-height: 130px !important;
  resize: vertical !important;
}
.admin-main input:focus,
.admin-main select:focus,
.admin-main textarea:focus,
.admin-panel input:focus,
.admin-panel select:focus,
.admin-panel textarea:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(29,185,84,.14) !important;
  outline: 0 !important;
}
.admin-main input[type="file"],
.admin-panel input[type="file"] {
  padding: 9px !important;
  background: var(--bg-light) !important;
}
.admin-actions,
.inline-actions,
.table-actions,
.bulk-actions {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  min-width: 0 !important;
}
.admin-actions .btn,
.inline-actions .btn,
.table-actions .btn,
.bulk-actions .btn {
  white-space: nowrap !important;
}

/* Smart submission assistant: the screenshot issue. */
.smart-flow {
  padding: 24px !important;
  display: grid !important;
  gap: 18px !important;
}
.smart-flow h2,
.smart-flow p {
  margin: 0 !important;
}
.smart-flow h2 {
  font-size: clamp(20px, 2.2vw, 28px) !important;
  letter-spacing: -.035em !important;
}
.smart-flow .admin-actions {
  margin: 6px 0 12px !important;
}
.smart-flow form.form-grid {
  margin-top: 8px !important;
  padding-top: 20px !important;
  border-top: 1px solid var(--border-light) !important;
}
.smart-flow [data-tag-suggestions] {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

/* Search/filter bars and command/search inputs. */
.admin-filter-bar,
.admin-search-form,
.admin-toolbar-form {
  padding: 18px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 12px 30px rgba(10,31,21,.06) !important;
  margin-bottom: 20px !important;
}
.admin-filter-bar .btn,
.admin-search-form .btn,
.admin-toolbar-form .btn {
  min-height: 46px !important;
}
.admin-search {
  height: 42px !important;
  min-width: 220px !important;
  max-width: 420px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.admin-search input {
  min-height: 38px !important;
}
.suggest-box {
  z-index: 999 !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(10,31,21,.16) !important;
  padding: 8px !important;
}

/* Tables: dashboard-wide cleanup, including checkbox columns and action cells. */
.admin-table-wrap,
.table-responsive,
.admin-panel > .admin-table-wrap,
.admin-panel > .table-responsive {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border-top: 1px solid var(--border-light) !important;
  background: #fff !important;
}
.admin-panel > .admin-table-wrap:first-child,
.admin-panel > .table-responsive:first-child {
  border-top: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.admin-table,
.admin-panel table {
  width: 100% !important;
  min-width: 760px !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  background: #fff !important;
  font-size: 13.5px !important;
}
.admin-table th,
.admin-panel table th {
  position: static !important;
  padding: 13px 16px !important;
  border-bottom: 1px solid var(--border-light) !important;
  background: #f4f8f4 !important;
  color: var(--muted) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .075em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  text-align: left !important;
}
.admin-table td,
.admin-panel table td {
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--border-light) !important;
  color: var(--text-dark) !important;
  vertical-align: middle !important;
  background: #fff !important;
  line-height: 1.45 !important;
}
.admin-table tbody tr:nth-child(even) td,
.admin-panel table tbody tr:nth-child(even) td {
  background: #fcfdfc !important;
}
.admin-table tbody tr:hover td,
.admin-panel table tbody tr:hover td {
  background: #f6fbf6 !important;
}
.admin-table td:first-child,
.admin-panel table td:first-child,
.admin-table th:first-child,
.admin-panel table th:first-child {
  padding-left: 20px !important;
}
.admin-table td:last-child,
.admin-panel table td:last-child,
.admin-table th:last-child,
.admin-panel table th:last-child {
  padding-right: 20px !important;
}
.admin-table td:has(input[type="checkbox"]),
.admin-panel table td:has(input[type="checkbox"]),
.admin-table th:has(input[type="checkbox"]),
.admin-panel table th:has(input[type="checkbox"]) {
  width: 52px !important;
  text-align: center !important;
}
.admin-table input[type="checkbox"],
.admin-panel table input[type="checkbox"] {
  margin: 0 auto !important;
}
.admin-table code,
.admin-panel table code {
  display: inline-block !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
  padding: 3px 7px !important;
  color: var(--primary-dark) !important;
}
.admin-table .btn,
.admin-panel table .btn,
.admin-table button,
.admin-panel table button {
  white-space: nowrap !important;
}
.admin-table .inline-form-grid,
.admin-panel table .inline-form-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(110px, 1fr)) !important;
  gap: 8px !important;
  min-width: 340px !important;
}
.admin-table .inline-form,
.admin-panel table .inline-form,
.admin-table form,
.admin-panel table form {
  margin: 0 !important;
}

.table-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 15px 24px !important;
  border-bottom: 1px solid var(--border-light) !important;
  color: var(--text-dark) !important;
  background: #fff !important;
}
.table-row:last-child { border-bottom: 0 !important; }
.table-row > * { min-width: 0 !important; }
.table-row strong { display: block !important; color: var(--text-dark) !important; }
.table-row small { display: block !important; color: var(--muted) !important; margin-top: 3px !important; line-height: 1.4 !important; }
.table-row .inline-form,
.table-row form {
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

/* Checkbox/radio labels: no giant icons or floating checks. */
.admin-main input[type="checkbox"],
.admin-panel input[type="checkbox"] {
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  flex: 0 0 20px !important;
}
.notif-pref-row,
.notification-pref-item,
.check-row,
.admin-check-row {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 14px 0 !important;
  border-bottom: 1px solid var(--border-light) !important;
}
.notif-pref-row:first-of-type,
.notification-pref-item:first-of-type { padding-top: 0 !important; }
.notif-pref-row input,
.notification-pref-item input,
.check-row input,
.admin-check-row input {
  margin-top: 2px !important;
}
.notif-pref-row span,
.notification-pref-item span,
.check-row span,
.admin-check-row span {
  min-width: 0 !important;
}

/* Empty states and metric cards. */
.admin-empty-state {
  padding: clamp(28px, 4vw, 46px) !important;
  border: 1px dashed #cddccd !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f7faf7 !important;
  color: var(--muted) !important;
  display: grid !important;
  place-items: center !important;
  gap: 8px !important;
  text-align: center !important;
}
.admin-empty-state strong,
.admin-empty-state h3 {
  color: var(--text-dark) !important;
  margin: 0 !important;
}
.metric-card {
  padding: 20px !important;
}
.metric-card span,
.metric-card .kpi-label {
  margin-bottom: 8px !important;
}
.metric-card strong,
.metric-card .kpi-number {
  line-height: 1 !important;
}

/* Pricing compare screenshot fix: keep comparison table contained and centered. */
.pricing-compare-section {
  padding: clamp(64px, 7vw, 94px) 0 !important;
  overflow-x: hidden !important;
}
.pricing-compare-section .section-heading {
  width: min(900px, calc(100% - 48px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.pricing-compare-section .pricing-compare-table,
.table-responsive.pricing-compare-table {
  width: min(1120px, calc(100% - 48px)) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: var(--shadow) !important;
  overflow-x: auto !important;
  background: #fff !important;
}
.pricing-compare-table table {
  min-width: 820px !important;
}
.pricing-compare-table th,
.pricing-compare-table td {
  white-space: normal !important;
}

/* Admin navigation loading/performance feedback. */
.admin-pjax-loading .admin-main {
  cursor: progress !important;
}
.admin-pjax-loading::before {
  content: '';
  position: fixed;
  left: var(--admin-sidebar-width-expanded);
  right: 0;
  top: 0;
  height: 3px;
  z-index: 1000;
  background: linear-gradient(90deg, transparent, var(--primary), transparent);
  animation: inrepAdminLoading 1s linear infinite;
}
body.admin-sidebar-collapsed.admin-pjax-loading::before {
  left: var(--admin-sidebar-width-collapsed);
}
@keyframes inrepAdminLoading {
  from { transform: translateX(-100%); }
  to { transform: translateX(100%); }
}

@media (max-width: 1100px) {
  .admin-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .admin-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 1023px) {
  .admin-main {
    padding: 16px !important;
  }
  .admin-main > .admin-breadcrumbs,
  .admin-main > .admin-alert,
  .admin-main > .admin-page,
  .admin-main > .admin-panel,
  .admin-main > .admin-grid,
  .admin-main > .metric-card,
  .admin-main > form,
  .admin-main > div:not(.suggest-box) {
    max-width: 100% !important;
  }
  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4 {
    grid-template-columns: 1fr !important;
  }
  .admin-page-header {
    align-items: stretch !important;
    flex-direction: column !important;
  }
  .admin-page-header form,
  .admin-page-header .btn,
  .admin-page-header .admin-actions {
    width: 100% !important;
  }
  .admin-page-header .admin-actions .btn,
  .admin-page-header form .btn {
    width: auto !important;
  }
  .admin-main form.form-grid,
  .admin-main .form-grid,
  form.admin-panel.form-grid,
  .admin-panel form.form-grid,
  .admin-panel .form-grid,
  .admin-filter-bar,
  .admin-search-form,
  .admin-toolbar-form {
    grid-template-columns: 1fr !important;
  }
  .admin-panel > h2,
  .admin-panel > h3,
  .admin-panel > .form-section-title,
  .admin-panel > .panel-title {
    padding: 18px 18px 10px !important;
  }
  .admin-panel-body,
  form.admin-panel.form-grid,
  .smart-flow {
    padding: 18px !important;
  }
  .admin-panel > form.form-grid {
    padding: 0 18px 18px !important;
  }
  .admin-panel > p,
  .admin-panel > small,
  .admin-panel > .mini-muted,
  .admin-panel > .admin-help-list,
  .admin-panel > .clean-list,
  .admin-panel > .review-list,
  .admin-panel > .heatmap-list,
  .admin-panel > .tag-cloud,
  .admin-panel > .public-tag-cloud,
  .admin-panel > .project-status-line,
  .admin-panel > .inline-actions,
  .admin-panel > .admin-actions,
  .admin-panel > .table-row,
  .admin-panel > pre,
  .admin-panel > code,
  .admin-panel > .admin-alert,
  .admin-panel > .admin-empty-state,
  .admin-panel > .smart-flow,
  .admin-panel > .readiness-card,
  .admin-panel > .webhook-url-grid,
  .admin-panel > .payment-settings-form,
  .admin-panel > .subscription-choice-form {
    margin-left: 18px !important;
    margin-right: 18px !important;
  }
  .admin-table,
  .admin-panel table {
    min-width: 680px !important;
  }
  .table-row {
    align-items: flex-start !important;
    flex-direction: column !important;
    padding: 14px 18px !important;
  }
  .table-row > span:last-child,
  .table-row > div:last-child,
  .table-row > form:last-child {
    width: 100% !important;
  }
  .admin-pjax-loading::before {
    left: 0 !important;
  }
}
@media (max-width: 560px) {
  .admin-main { padding: 12px !important; }
  .admin-panel,
  form.admin-panel,
  .admin-repo-list-card,
  .dash-card,
  .metric-card {
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .admin-filter-bar,
  .admin-search-form,
  .admin-toolbar-form {
    padding: 14px !important;
  }
  .smart-flow .admin-actions .btn {
    width: 100% !important;
  }
  .pricing-compare-section .pricing-compare-table,
  .table-responsive.pricing-compare-table {
    width: min(100% - 28px, 1120px) !important;
  }
}



/* =======================================
   ADVANCED REPOSITORY FEATURE SUITE
   ======================================= */
.admin-page-head.enhancement-page-head,
.admin-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 22px;
}
.enhancement-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.enhancement-card {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 220px;
  padding: 22px;
  border: 1px solid var(--admin-border, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 12px 36px rgba(10,31,21,.08);
  color: var(--text-dark, #0a0a0a);
}
.enhancement-card:hover { transform: translateY(-2px); box-shadow: 0 18px 46px rgba(10,31,21,.13); color: var(--text-dark, #0a0a0a); }
.enhancement-card h2 { font-size: 18px; line-height: 1.25; margin: 0; }
.enhancement-card p { margin: 0; color: var(--muted, #6b7b6e); }
.enhancement-card small { color: var(--primary, #1db954); font-weight: 700; margin-top: auto; }
.metric-grid.enhancement-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.enhancement-metrics .metric-card small { display:block; margin-top: 8px; color: var(--muted, #6b7b6e); }
.enhancement-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 18px;
  align-items: start;
}
.enhancement-main-panel,
.enhancement-settings-panel { overflow: visible; }
.enhancement-capabilities {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}
.enhancement-capabilities span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 12px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--green-soft, #d4f5e0);
  color: var(--green-dark, #17a348);
  font-weight: 700;
  font-size: 12px;
  border: 1px solid rgba(29,185,84,.25);
}
.enhancement-table th,
.enhancement-table td { min-width: 150px; }
.enhancement-form { display: grid; gap: 12px; }
.enhancement-form label:not(.check-row) { margin: 4px 0 -4px; }
.enhancement-form .check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--admin-border, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--admin-bg, #f5f7f2);
  font-weight: 700;
}
.enhancement-form .check-row input { width: 18px; height: 18px; min-height: 18px; flex: 0 0 auto; }
.enhancement-form .btn { width: 100%; margin-top: 8px; }
@media (max-width: 1100px) {
  .metric-grid.enhancement-metrics { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .enhancement-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .admin-page-head { display: grid; }
  .metric-grid.enhancement-metrics { grid-template-columns: 1fr; }
  .enhancement-card { min-height: 0; }
}

/* =======================================
   DASHBOARD TABLE/FORM FINAL HARDENING
   Fixes table toolbars, empty-state tables, checkbox tools and non-grid forms.
   ======================================= */
.admin-panel > form:not(.inline-actions):not(.inline-form):not(.table-inline-form),
.admin-panel .stacked-form,
.admin-panel .compact-form,
.admin-main .stacked-form,
.admin-main .compact-form {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  padding: 0 24px 24px !important;
  margin: 0 !important;
  min-width: 0 !important;
}
form.admin-panel.stacked-form,
form.admin-panel.compact-form {
  padding: 24px !important;
}
.admin-panel .stacked-form .btn,
.admin-panel .compact-form .btn,
.admin-panel > form:not(.inline-actions):not(.inline-form):not(.table-inline-form) > .btn,
.admin-panel > form:not(.inline-actions):not(.inline-form):not(.table-inline-form) > button[type="submit"] {
  justify-self: start !important;
}
.admin-panel .stacked-form > .btn-primary,
.admin-panel .stacked-form > .btn.primary,
.admin-panel .compact-form > .btn-primary,
.admin-panel .compact-form > .btn.primary {
  min-width: 180px !important;
}
.admin-panel .check-list,
.admin-main .check-list {
  list-style: none !important;
  display: grid !important;
  gap: 12px !important;
  margin: 0 24px 24px !important;
  padding: 0 !important;
}
.admin-panel .check-list li,
.admin-main .check-list li {
  position: relative !important;
  padding: 13px 14px 13px 42px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf8 !important;
  color: var(--text-dark) !important;
  font-weight: 600 !important;
}
.admin-panel .check-list li::before,
.admin-main .check-list li::before {
  content: '\2713' !important;
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid !important;
  place-items: center !important;
  background: var(--primary) !important;
  color: #fff !important;
  font-size: 12px !important;
  line-height: 1 !important;
}
.admin-list,
.compact-list {
  display: grid !important;
  gap: 12px !important;
  margin: 0 24px 24px !important;
  padding: 0 !important;
}
.admin-list-item,
.compact-list .admin-list-item {
  display: grid !important;
  gap: 5px !important;
  padding: 15px 16px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark) !important;
}
.admin-list-item p { margin: 0 !important; color: var(--muted) !important; }
.admin-list-item small { color: var(--muted) !important; }

.table-toolbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--border-light) !important;
  background: #fff !important;
  position: relative !important;
  z-index: 5 !important;
}
.table-toolbar .btn,
.table-toolbar button {
  width: auto !important;
  min-height: 34px !important;
  padding: 7px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  white-space: nowrap !important;
}
.table-bulk-actions {
  display: inline-flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  color: var(--text-dark) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
}
.table-bulk-actions:not(.is-visible) [data-bulk-export] {
  display: none !important;
}
.table-columns-menu {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
}
.table-columns-panel {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  width: min(260px, calc(100vw - 32px)) !important;
  max-height: 320px !important;
  overflow: auto !important;
  display: none !important;
  padding: 8px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 44px rgba(10,31,21,.16) !important;
  z-index: 30 !important;
}
.table-columns-menu.is-open .table-columns-panel {
  display: grid !important;
  gap: 2px !important;
}
.admin-main .table-columns-panel label,
.admin-panel .table-columns-panel label,
.table-columns-panel label {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 9px !important;
  min-height: 34px !important;
  padding: 7px 8px !important;
  margin: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: var(--text-dark) !important;
  font-size: 13px !important;
  font-weight: 650 !important;
  line-height: 1.25 !important;
  cursor: pointer !important;
}
.table-columns-panel label:hover { background: var(--bg-light) !important; }
.table-columns-panel input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  margin: 0 !important;
  flex: 0 0 18px !important;
}
.admin-table-wrap .admin-empty-state,
.table-responsive .admin-empty-state,
td .admin-empty-state {
  margin: 24px !important;
}
.admin-table td[colspan] .admin-empty-state,
.admin-panel table td[colspan] .admin-empty-state {
  min-height: 160px !important;
}
.admin-table tr.is-empty-row td,
.admin-panel table tr.is-empty-row td,
.admin-table td:has(.admin-empty-state),
.admin-panel table td:has(.admin-empty-state) {
  padding: 0 !important;
  background: #fff !important;
}
.admin-table tr.is-empty-row:hover td,
.admin-panel table tr.is-empty-row:hover td {
  background: #fff !important;
}
.admin-table th:first-child input[type="checkbox"],
.admin-table td:first-child input[type="checkbox"],
.admin-panel table th:first-child input[type="checkbox"],
.admin-panel table td:first-child input[type="checkbox"] {
  display: inline-grid !important;
  appearance: auto !important;
  accent-color: var(--primary) !important;
}
.admin-table .table-actions,
.admin-panel table .table-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  min-width: 170px !important;
}
.admin-table .table-actions form,
.admin-panel table .table-actions form {
  display: inline-flex !important;
  margin: 0 !important;
  padding: 0 !important;
}
.admin-table .status-badge,
.admin-panel table .status-badge,
.admin-table .pill,
.admin-panel table .pill {
  white-space: nowrap !important;
}
.admin-table-wrap + .admin-empty-state,
.table-responsive + .admin-empty-state {
  margin-top: 18px !important;
}

@media (max-width: 720px) {
  .table-toolbar {
    align-items: stretch !important;
    flex-direction: column !important;
  }
  .table-toolbar > *,
  .table-bulk-actions,
  .table-columns-menu,
  .table-toolbar .btn {
    width: 100% !important;
  }
  .table-bulk-actions {
    justify-content: space-between !important;
  }
  .table-columns-panel {
    position: static !important;
    width: 100% !important;
    max-height: 240px !important;
    margin-top: 8px !important;
    box-shadow: none !important;
  }
  .admin-panel > form:not(.inline-actions):not(.inline-form):not(.table-inline-form),
  .admin-panel .stacked-form,
  .admin-panel .compact-form,
  .admin-panel .check-list,
  .admin-list,
  .compact-list {
    margin-left: 18px !important;
    margin-right: 18px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}


/* 2026-05-12 enterprise operations/dashboard polish */
.admin-sidebar { overscroll-behavior: contain; scrollbar-gutter: stable; }
.admin-sidebar-label { width: 100%; display: flex !important; align-items: center; justify-content: space-between; gap: 10px; min-height: 34px; padding: 8px 10px; border-radius: var(--inrep-radius, 10px) !important; background: transparent; color: rgba(255,255,255,.45); }
.admin-sidebar-label-text { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.admin-sidebar-chevron { flex: 0 0 auto; line-height: 1; transform-origin: center; transition: transform .18s ease; }
.admin-sidebar-section.is-collapsed .admin-sidebar-chevron { transform: rotate(-90deg); }
.admin-sidebar-section.is-collapsed [data-sidebar-links] { display: none !important; }
body.admin-sidebar-collapsed .admin-sidebar-label { display: none !important; }

.admin-page { max-width: 1480px; margin: 0 auto; width: 100%; }
.admin-page-header { display:flex; align-items:flex-start; justify-content:space-between; gap:18px; margin-bottom:22px; }
.admin-page-subtitle { color: var(--muted); margin: 6px 0 0; max-width: 760px; }
.admin-grid { display:grid; gap:20px; }
.admin-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.admin-panel { overflow: hidden; }
.admin-panel > h2 { padding: 18px 22px; margin: 0; border-bottom: 1px solid var(--border-light); }
.admin-panel-body { padding: 22px; }
.admin-form-panel { margin-bottom: 22px; }
.admin-form-grid, .public-form, form.admin-form-grid { display:grid; gap:18px; align-items:start; }
.admin-form-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.admin-form-grid label, .admin-panel label { display:grid; gap:7px; margin:0; font-weight:700; }
.admin-form-grid input, .admin-form-grid select, .admin-form-grid textarea,
.admin-panel input, .admin-panel select, .admin-panel textarea { min-height:46px; border-radius:var(--inrep-radius, 10px) !important; }
.admin-form-actions { display:flex; justify-content:flex-end; gap:10px; align-items:center; }
.span-full { grid-column: 1 / -1; }

.admin-table-wrap, .table-responsive { width:100%; overflow:auto; border-radius: var(--inrep-radius, 10px) !important; }
.admin-table-wrap table, .admin-main table { min-width: 760px; border-collapse: collapse; background:#fff; }
.admin-table-wrap th, .admin-table-wrap td, .admin-main table th, .admin-main table td { padding: 14px 16px; vertical-align: middle; }
.admin-table-wrap thead th, .admin-main table thead th { position: sticky; top: 0; z-index: 2; background: var(--bg-light); color: var(--muted); font-size: 12px; letter-spacing:.08em; text-transform: uppercase; }
.admin-table-wrap tbody tr:hover td { background: #fbfefb; }
.admin-main table input[type="checkbox"] { width:22px !important; height:22px !important; min-height:22px !important; padding:0 !important; accent-color: var(--primary); }
.table-actions, .admin-table-actions, .admin-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.admin-empty-state { min-height: 150px; display:grid; place-items:center; text-align:center; gap:10px; padding:32px; border:1px dashed var(--border-light); border-radius:var(--inrep-radius, 10px) !important; background:var(--bg-light); color:var(--muted); }
.admin-empty-state strong { color:var(--text-dark); font-size:18px; }

.db-table-toolbar { align-items:center; }
.db-table-search { display:flex; gap:10px; width:100%; align-items:center; }
.db-table-search input { max-width:420px; }
.db-table-wrap { max-height: calc(100vh - 290px); }
.db-action-col { position: sticky; left: 0; z-index: 3; background:#fff; box-shadow: 1px 0 0 var(--border-light); width: 92px; min-width: 92px; }
thead .db-action-col { background: var(--bg-light); z-index:4; }
.db-table-cell { max-width: 360px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.db-null { color: var(--muted); font-style: italic; }
.db-pagination { padding:16px 20px; border-top:1px solid var(--border-light); }

.operations-page .admin-page-header { margin-bottom:24px; }
.operations-storage-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px; margin-bottom:22px; }
.operations-card { background:#fff; border:1px solid var(--border-light); border-radius:var(--inrep-radius, 10px) !important; box-shadow:var(--shadow); padding:22px; display:grid; gap:10px; }
.operations-card h2 { margin:0; font-size:20px; }
.operations-card p { margin:0; color: var(--text-dark); font-weight:650; }
.operations-card small { color:var(--muted); line-height:1.6; }

.pricing-compare-section { padding: 74px 0; }
.pricing-compare-table { width:min(1180px, calc(100% - 48px)); margin:0 auto; border:1px solid var(--border-light); border-radius:var(--inrep-radius, 10px) !important; box-shadow:var(--shadow); }
.pricing-compare-table table { min-width: 920px; }
.pricing-compare-table th, .pricing-compare-table td { padding:18px 22px; }

@media (max-width: 1024px) {
  .admin-page-header { flex-direction:column; }
  .admin-grid-2, .admin-grid-3, .admin-form-grid-2, .admin-form-grid-3, .operations-storage-grid { grid-template-columns:1fr; }
  .admin-actions { width:100%; }
  .db-table-search { flex-direction:column; align-items:stretch; }
  .db-table-search input { max-width:none; }
}
@media (max-width: 640px) {
  .admin-main { padding: 16px 12px; }
  .admin-panel-body { padding: 16px; }
  .admin-table-wrap table, .admin-main table { min-width: 680px; }
}



/* ===============================================
   NAV SIMPLIFICATION + TIER-LOCKED STORAGE PATCH
   =============================================== */

/* Keep the shortened sidebar calm and easy to scan */
.admin-sidebar {
  scroll-behavior: auto !important;
}
.admin-sidebar-section {
  margin-bottom: 4px !important;
}
.admin-sidebar-links {
  gap: 3px !important;
}
.admin-sidebar-link {
  min-height: 40px !important;
}
.admin-sidebar-link span {
  font-size: 13px !important;
}

/* Long navigation support: preserve pinned/recent but keep them compact */
.admin-sidebar-pinned:not([hidden]),
.admin-sidebar-recent:not([hidden]) {
  max-height: 170px !important;
  overflow-y: auto !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

/* Upload page storage is a locked tier result, not a user choice */
.storage-tier-lock-panel {
  margin-bottom: 18px !important;
}
.storage-tier-lock {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, .58fr);
  gap: 18px;
  align-items: stretch;
}
.storage-tier-lock > div {
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  padding: 20px;
}
.storage-tier-lock h3 {
  margin: 10px 0 8px;
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -.03em;
  color: var(--text-dark);
}
.storage-tier-lock p,
.storage-tier-lock small,
.storage-tier-note span {
  color: var(--text-muted-dark);
  line-height: 1.65;
}
.storage-tier-note {
  display: grid;
  gap: 8px;
  background: var(--bg-light) !important;
}
.storage-tier-note strong,
.storage-tier-rule {
  color: var(--text-dark);
}
.storage-mode-grid,
.storage-choice {
  display: none !important;
}
.storage-panel.is-active {
  display: block !important;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  padding: 20px;
}
.storage-panel.is-active > h3 {
  margin-top: 0;
  font-family: var(--font-display);
}
.storage-panel .form-grid {
  margin-top: 16px;
}
.storage-tier-policy-note {
  display: grid;
  gap: 4px;
  margin-bottom: 18px;
}
.storage-tier-policy-grid .operations-card {
  display: grid;
  gap: 10px;
}
.storage-tier-managed-message {
  display: grid;
  gap: 12px;
  padding: 22px;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
}
.storage-tier-managed-message p {
  margin: 0;
  color: var(--text-muted-dark);
}
.storage-tier-managed-message .btn {
  justify-self: start;
}

@media (max-width: 820px) {
  .storage-tier-lock {
    grid-template-columns: 1fr;
  }
}


/* Remove sidebar recent/pinned shortcut links from the top of the dashboard nav */
.admin-sidebar-recent,
.admin-sidebar-pinned,
.admin-sidebar-shortcuts,
.sidebar-recent,
.sidebar-pinned {
  display: none !important;
}


/* ===============================================
   2026-05-07 FINAL DASHBOARD/TABLE/FORM REPAIR
   Targeted: no structure changes, only CSS stabilization.
   =============================================== */
body.admin-fullscreen { overflow: hidden !important; }
.admin-shell { height: 100dvh !important; min-height: 100dvh !important; overflow: hidden !important; }
.admin-sidebar { height: 100dvh !important; overflow-y: auto !important; overflow-x: hidden !important; scrollbar-gutter: stable !important; }
.admin-main { height: calc(100dvh - 64px) !important; overflow-y: auto !important; overflow-x: hidden !important; padding: 28px !important; }
.admin-topbar { z-index: 100 !important; }
.admin-sidebar-overlay { backdrop-filter: none !important; -webkit-backdrop-filter: none !important; background: rgba(10,31,21,.18) !important; }
body.admin-sidebar-open .admin-main,
body.admin-sidebar-open .admin-topbar { filter: none !important; }

.admin-sidebar-label { cursor: pointer !important; font-size: 11px !important; font-weight: 850 !important; letter-spacing: .09em !important; text-transform: uppercase !important; }
.admin-sidebar-chevron { display: inline-grid !important; place-items: center !important; width: 16px !important; height: 16px !important; font-size: 12px !important; opacity: .75 !important; }
.admin-sidebar-section.is-collapsed .admin-sidebar-chevron { transform: rotate(-90deg) !important; }
.admin-sidebar-link.active,
.admin-sidebar-link[aria-current="page"] { background: rgba(29,185,84,.18) !important; color: #fff !important; box-shadow: inset 3px 0 0 var(--primary) !important; }
.admin-sidebar-link.active svg { color: var(--accent-green) !important; }

.admin-page { width: 100% !important; max-width: 1480px !important; margin: 0 auto !important; }
.admin-page-header { margin: 0 0 24px !important; display: flex !important; align-items: flex-start !important; justify-content: space-between !important; gap: 14px !important; flex-wrap: wrap !important; }
.admin-page-header > div:first-child { flex: 1 1 240px !important; min-width: 0 !important; }
.admin-page-header .admin-actions { flex: 0 0 auto !important; flex-wrap: wrap !important; justify-content: flex-end !important; align-items: center !important; }
.admin-page-title { margin: 0 0 6px !important; line-height: 1.1 !important; letter-spacing: -.04em !important; font-size: clamp(18px, 2vw, 28px) !important; }
.admin-page-subtitle { margin: 0 !important; color: var(--text-muted-dark) !important; max-width: 820px !important; font-size: 13px !important; }

.admin-panel,
form.admin-panel,
.admin-card,
.dash-card,
.metric-card { border-radius: var(--inrep-radius, 10px) !important; border: 1px solid var(--border-light) !important; background: #fff !important; box-shadow: 0 12px 34px rgba(10,31,21,.075) !important; overflow: hidden !important; min-width: 0 !important; }
.admin-panel + .admin-panel,
.admin-panel + .admin-grid,
.admin-grid + .admin-panel,
.admin-grid + .admin-grid { margin-top: 22px !important; }
.admin-panel > h2,
.admin-panel > h3 { margin: 0 !important; padding: 20px 24px 12px !important; border-bottom: 1px solid var(--border-light) !important; font-size: clamp(18px, 1.45vw, 22px) !important; line-height: 1.2 !important; }
.admin-panel > p,
.admin-panel > .admin-page-subtitle,
.admin-panel > .mini-muted { padding-left: 24px !important; padding-right: 24px !important; }
.panel-head,
.admin-panel-header { padding: 18px 24px !important; gap: 14px !important; align-items: center !important; }
.admin-panel-body { padding: 24px !important; }

.admin-grid { display: grid !important; gap: 22px !important; min-width: 0 !important; }
.admin-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
.admin-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
.admin-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }

.admin-main form:not(.inline-form):not(.admin-logout-form):not(.admin-profile-logout-form),
.admin-panel form:not(.inline-form):not(.admin-logout-form):not(.admin-profile-logout-form) { min-width: 0 !important; }
.admin-main .form-grid,
.admin-main .public-form,
.admin-main .admin-form-grid,
.admin-main form.form-grid,
.admin-main form.public-form,
.admin-main form.admin-form-grid { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 18px !important; align-items: start !important; }
.admin-main .form-grid > h2,
.admin-main .public-form > h2,
.admin-main .admin-form-grid > h2 { grid-column: 1 / -1 !important; margin-bottom: 0 !important; }
.admin-main form.admin-panel.form-grid,
.admin-main form.admin-panel.public-form,
.admin-main form.admin-panel.admin-form-grid { padding: 24px !important; }
.admin-panel > form.form-grid,
.admin-panel > form.public-form,
.admin-panel > form.admin-form-grid { padding: 24px !important; }
.admin-main label,
.admin-panel label { display: grid !important; gap: 7px !important; margin: 0 !important; min-width: 0 !important; font-weight: 750 !important; color: var(--text-dark) !important; }
.admin-main .span-full,
.admin-main .full,
.admin-main label.full,
.admin-panel .span-full,
.admin-panel .full,
.admin-panel label.full,
.admin-main form > button[type="submit"],
.admin-panel form > button[type="submit"] { grid-column: 1 / -1 !important; }
.admin-main input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]):not([type="submit"]):not([type="button"]),
.admin-main select,
.admin-main textarea { min-height: 46px !important; border: 1px solid var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; background: #fff !important; padding: 10px 14px !important; width: 100% !important; min-width: 0 !important; color: var(--text-dark) !important; }
.admin-main textarea { min-height: 130px !important; }
.admin-main input[type="checkbox"],
.admin-panel input[type="checkbox"] { width: 18px !important; height: 18px !important; min-width: 18px !important; min-height: 18px !important; margin: 0 !important; padding: 0 !important; accent-color: var(--primary) !important; vertical-align: middle !important; }
.admin-main label:has(> input[type="checkbox"]) { display: flex !important; align-items: center !important; gap: 10px !important; }
.admin-form-actions,
.admin-actions,
.inline-actions,
.table-actions { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; align-items: center !important; }

.permission-grid { padding: 0 24px 24px !important; display: grid !important; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important; gap: 10px !important; }
.permission-grid label { display: flex !important; align-items: center !important; gap: 10px !important; min-height: 42px !important; padding: 10px 12px !important; border: 1px solid var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light) !important; font-size: 13px !important; overflow-wrap: anywhere !important; }
.permission-grid + .btn,
.permission-grid ~ .btn { margin: 0 24px 24px !important; }

.table-row { padding: 16px 24px !important; gap: 14px !important; }
.admin-table-wrap,
.table-responsive { width: 100% !important; max-width: 100% !important; overflow-x: auto !important; border-top: 1px solid var(--border-light) !important; background: #fff !important; }
.admin-table-wrap table,
.admin-main table { width: 100% !important; min-width: 760px !important; border-collapse: separate !important; border-spacing: 0 !important; background: #fff !important; }
.admin-table-wrap thead th,
.admin-main table thead th { position: static !important; background: #f4f8f4 !important; color: var(--text-muted-dark) !important; padding: 14px 16px !important; font-size: 11px !important; font-weight: 900 !important; letter-spacing: .08em !important; text-transform: uppercase !important; border-bottom: 1px solid var(--border-light) !important; white-space: nowrap !important; }
.admin-table-wrap tbody td,
.admin-main table tbody td { padding: 14px 16px !important; color: var(--text-dark) !important; border-bottom: 1px solid var(--border-light) !important; vertical-align: middle !important; background: #fff !important; }
.admin-table-wrap tbody tr:nth-child(even) td,
.admin-main table tbody tr:nth-child(even) td { background: #fcfdfc !important; }
.admin-table-wrap tbody tr:hover td,
.admin-main table tbody tr:hover td { background: #f7fbf7 !important; }
.admin-table-wrap td:has(.admin-empty-state),
.admin-main table td:has(.admin-empty-state) { padding: 0 !important; }
.admin-empty-state { margin: 20px !important; min-height: 150px !important; border: 1px dashed var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light) !important; display: grid !important; place-items: center !important; text-align: center !important; gap: 8px !important; padding: 28px !important; color: var(--text-muted-dark) !important; }
.admin-empty-state strong { color: var(--text-dark) !important; font-size: 17px !important; }

.widget-integration-row { display: grid !important; grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr) !important; gap: 20px !important; align-items: start !important; margin: 22px 0 !important; }
.widget-code-card,
.widget-preview-card { background: #fff !important; border: 1px solid var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; box-shadow: 0 12px 34px rgba(10,31,21,.07) !important; overflow: hidden !important; min-width: 0 !important; }
.widget-code-card textarea { min-height: 130px !important; border-radius: var(--inrep-radius, 10px) !important; border-left: 0 !important; border-right: 0 !important; }
.widget-code-card .form-help,
.widget-preview-card > strong { display: block !important; padding: 12px 18px !important; }
.widget-preview-card iframe { display: block !important; background: #fff !important; }

.admin-plan-grid { align-items: stretch !important; }
.subscription-choice-form { display: grid !important; grid-template-columns: repeat(2,minmax(0,1fr)) !important; gap: 12px !important; }
.subscription-choice-form button { grid-column: 1 / -1 !important; }
.payment-settings-form { grid-template-columns: repeat(2,minmax(0,1fr)) !important; }

.smart-flow { padding: 24px !important; }
.smart-flow .admin-actions { margin: 0 !important; }
.smart-flow form.form-grid { padding: 0 !important; }

.admin-filter-bar,
.admin-search-form,
.admin-toolbar-form { display: grid !important; grid-template-columns: repeat(3,minmax(0,1fr)) auto !important; gap: 14px !important; align-items: end !important; padding: 18px !important; border: 1px solid var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; background: #fff !important; }
.admin-filter-bar button,
.admin-search-form button,
.admin-toolbar-form button { min-height: 46px !important; }

@media (max-width: 1180px) {
  .admin-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .widget-integration-row { grid-template-columns: 1fr !important; }
}
@media (max-width: 1023px) {
  body.admin-fullscreen { overflow: hidden !important; }
  .admin-shell { grid-template-columns: 1fr !important; }
  .admin-sidebar { position: fixed !important; inset: 0 auto 0 0 !important; width: min(320px, 86vw) !important; z-index: 200 !important; transform: translateX(-105%) !important; transition: transform .22s ease !important; }
  body.admin-sidebar-open .admin-sidebar { transform: translateX(0) !important; }
  .admin-sidebar-overlay { display: block !important; position: fixed !important; inset: 0 !important; z-index: 190 !important; opacity: 0 !important; pointer-events: none !important; transition: opacity .18s ease !important; }
  body.admin-sidebar-open .admin-sidebar-overlay { opacity: 1 !important; pointer-events: auto !important; }
  .admin-main { height: calc(100dvh - 64px) !important; padding: 20px 16px !important; }
  .admin-topbar-menu { display: inline-flex !important; }
  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4,
  .admin-main .form-grid,
  .admin-main .public-form,
  .admin-main .admin-form-grid,
  .admin-filter-bar,
  .admin-search-form,
  .admin-toolbar-form,
  .payment-settings-form,
  .subscription-choice-form { grid-template-columns: 1fr !important; }
  .admin-page-header { align-items: stretch !important; flex-direction: column !important; }
}
@media (max-width: 640px) {
  .admin-main { padding: 16px 12px !important; }
  .admin-panel-body,
  .admin-panel > form.form-grid,
  .admin-panel > form.public-form,
  .admin-panel > form.admin-form-grid,
  form.admin-panel.form-grid { padding: 18px !important; }
  .permission-grid { grid-template-columns: 1fr !important; padding: 0 18px 18px !important; }
  .admin-table-wrap table,
  .admin-main table { min-width: 680px !important; }
}

/* ===============================================
   FIX60 FINAL STABILIZATION OVERRIDES
   =============================================== */
:root { --admin-max-content: 1480px; }
body.admin-fullscreen { background: var(--admin-bg) !important; }
.admin-shell { grid-template-columns: var(--admin-sidebar-width-expanded) minmax(0,1fr) !important; }
body.admin-sidebar-collapsed .admin-shell { grid-template-columns: var(--admin-sidebar-width-collapsed) minmax(0,1fr) !important; }
.admin-sidebar { scrollbar-width: thin; }
.admin-sidebar-header { position: sticky; top: 0; background: var(--admin-sidebar-bg); z-index: 3; }
.admin-sidebar-close { display: none !important; }
.admin-sidebar-collapse-toggle { display: grid !important; }
.admin-sidebar-label { width: 100% !important; min-height: 34px !important; display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 8px !important; padding: 8px 12px !important; border: 0 !important; background: transparent !important; color: rgba(255,255,255,.58) !important; }
body.admin-sidebar-collapsed .admin-sidebar-label { justify-content: center !important; padding-inline: 0 !important; }
body.admin-sidebar-collapsed .admin-sidebar-label-text,
body.admin-sidebar-collapsed .admin-sidebar-chevron { display:none !important; }
.admin-sidebar-links { display: grid !important; gap: 4px !important; }
.admin-sidebar-section.is-collapsed .admin-sidebar-links { display: none !important; }
.admin-sidebar-link { margin: 0 !important; min-width: 40px !important; }
.admin-sidebar-link svg { width: 17px !important; height: 17px !important; }
body.admin-sidebar-collapsed .admin-sidebar-link { width: 40px !important; height: 40px !important; padding: 0 !important; justify-content: center !important; }
body.admin-sidebar-collapsed .admin-sidebar-link span { display: none !important; }

.admin-topbar { grid-column: 2 !important; position: sticky !important; top: 0 !important; height: 64px !important; }
.admin-readiness-banner { grid-column: 2 !important; }
.admin-main { grid-column: 2 !important; max-width: none !important; }
.admin-main > .admin-page,
.admin-main > section,
.admin-main > .admin-panel,
.admin-main > .admin-grid,
.admin-breadcrumbs,
.admin-alert { max-width: var(--admin-max-content) !important; margin-left: auto !important; margin-right: auto !important; }
.admin-main > .admin-page { margin-top: 0 !important; }
.admin-main .admin-page > .admin-panel,
.admin-main .admin-page > .admin-grid,
.admin-main .admin-page > .admin-plan-grid,
.admin-main .admin-page > .admin-table-wrap { margin-top: 22px !important; }

.admin-panel > form:not(.inline-form),
.admin-card > form:not(.inline-form),
.dash-card > form:not(.inline-form) { padding: 24px !important; }
.admin-main .form-grid > label,
.admin-main .admin-form-grid > label,
.admin-main .public-form > label { min-width: 0 !important; }
.admin-main .admin-form-grid textarea,
.admin-main .form-grid textarea { min-height: 150px !important; }
.admin-main .btn.primary,
.admin-main button.btn.primary,
.admin-main form button[type="submit"] { min-height: 42px !important; }

.admin-table-wrap,
.table-responsive { border: 1px solid var(--border-light) !important; border-radius: var(--inrep-radius, 10px) !important; overflow: auto !important; background: #fff !important; box-shadow: none !important; }
.admin-panel > .admin-table-wrap,
.admin-card > .admin-table-wrap { border-left: 0 !important; border-right: 0 !important; border-bottom: 0 !important; border-radius: var(--inrep-radius, 10px) !important; }
.table-toolbar { display:flex !important; align-items:center !important; justify-content:space-between !important; gap:12px !important; flex-wrap:wrap !important; padding:12px 16px !important; border:1px solid var(--border-light) !important; border-bottom:0 !important; border-radius:var(--inrep-radius, 10px) !important; background:#fff !important; }
.table-bulk-actions { display:flex !important; align-items:center !important; gap:8px !important; flex-wrap:wrap !important; }
.table-columns-menu { position:relative !important; }
.table-columns-panel { position:absolute !important; right:0 !important; top:calc(100% + 8px) !important; min-width:220px !important; max-height:320px !important; overflow:auto !important; padding:10px !important; border:1px solid var(--border-light) !important; border-radius:var(--inrep-radius, 10px) !important; background:#fff !important; box-shadow:var(--shadow-lg) !important; z-index:20 !important; display:none !important; }
.table-columns-menu.is-open .table-columns-panel { display:grid !important; gap:8px !important; }
.table-columns-panel label { display:flex !important; align-items:center !important; gap:8px !important; font-size:13px !important; }
.admin-main table input[type="checkbox"] { display:inline-block !important; }
.admin-row-select,
.admin-select-all { inline-size:18px !important; block-size:18px !important; }

.permission-grid { align-items:start !important; }
.permission-grid label { color:var(--text-dark) !important; }
.smart-flow,
[data-smart-submission] { display:grid !important; gap:22px !important; }
[data-smart-submission] .admin-actions { padding:0 !important; }
[data-smart-submission] .admin-actions .btn { min-width: 150px !important; }

.widget-code-card textarea,
.admin-main textarea.code,
.admin-main code,
.admin-main pre { overflow:auto !important; white-space:pre-wrap !important; overflow-wrap:anywhere !important; }

.contact-grid { padding-top: 48px !important; padding-bottom: 56px !important; }
.contact-card { padding: 32px !important; }
.contact-support-grid div { padding: 18px 0 !important; }
.page-hero + .contact-section,
.page-hero + .section-soft { margin-top: 0 !important; }

.mkt-nav { position: sticky !important; top: 0 !important; z-index: 240 !important; }
body.public-nav-open { overflow:hidden !important; }
.mkt-mobile-overlay { backdrop-filter:none !important; -webkit-backdrop-filter:none !important; background:rgba(10,31,21,.18) !important; }
body.public-nav-open .mkt-mobile-overlay { opacity:1 !important; pointer-events:auto !important; }
.mkt-mobile-drawer { z-index: 300 !important; }
.cards-section, .workflow-section, .audience-section, .search-preview-section, .pricing-page-section, .pricing-compare-section { padding-top: 84px !important; padding-bottom: 84px !important; }
.mkt-hero + .stats-strip,
.mkt-hero + .stats-section { margin-top: 0 !important; }
.university-search-panel,
.institution-search,
.public-repository-search,
.hero-search { width:min(920px, calc(100% - 32px)) !important; margin-left:auto !important; margin-right:auto !important; }

@media (max-width: 1023px) {
  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell { grid-template-columns: 1fr !important; }
  .admin-topbar,
  .admin-readiness-banner,
  .admin-main { grid-column: 1 !important; }
  .admin-sidebar { width:min(312px, 86vw) !important; }
  .admin-sidebar-close { display:grid !important; }
  .admin-sidebar-collapse-toggle { display:none !important; }
  body.admin-sidebar-open .admin-sidebar-overlay { opacity:1 !important; pointer-events:auto !important; }
  .admin-topbar { padding:0 12px !important; gap:8px !important; }
  .admin-topbar-title { max-width: 32vw !important; overflow:hidden !important; text-overflow:ellipsis !important; white-space:nowrap !important; }
  .admin-search { display:none !important; }
  .admin-topbar-action-labeled .admin-icon-label { display:none !important; }
  .admin-logout-form { display:none !important; }
  .admin-main { padding:18px 14px !important; }
  .admin-main > .admin-page,
  .admin-main > section,
  .admin-main > .admin-panel,
  .admin-main > .admin-grid,
  .admin-breadcrumbs,
  .admin-alert { max-width:100% !important; }
  .table-toolbar { align-items:stretch !important; }
  .table-toolbar > *, .table-bulk-actions { width:100% !important; justify-content:flex-start !important; }
}
@media (max-width: 700px) {
  .contact-grid { padding-top: 36px !important; padding-bottom: 42px !important; }
  .contact-card { padding: 24px !important; }
  .admin-main .form-grid,
  .admin-main .admin-form-grid,
  .admin-main .public-form { grid-template-columns: 1fr !important; }
  .cards-section, .workflow-section, .audience-section, .search-preview-section, .pricing-page-section, .pricing-compare-section { padding-top: 56px !important; padding-bottom: 56px !important; }
}

/* FIX60 - plan-locked storage forms */
.storage-plan-summary {
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light, #f5f7f2);
}
.storage-plan-summary strong {
  font-family: var(--font-display, sans-serif);
  font-size: 18px;
  color: var(--text-dark, #0a0a0a);
}
.storage-plan-summary p { margin: 0; color: var(--text-muted-dark, #6b7b6e); }
.storage-tier-lock-panel { margin-bottom: 18px; }
.storage-tier-lock { display: grid; grid-template-columns: minmax(0, 1fr) minmax(260px, .7fr); gap: 18px; align-items: stretch; }
.storage-tier-lock > div { padding: 18px; border: 1px solid var(--border-light, #e0e8e2); border-radius: var(--inrep-radius, 10px) !important; background: #fff; }
.storage-tier-lock h3 { margin: 8px 0 6px; font-size: 20px; }
.storage-tier-note { display: grid; gap: 6px; align-content: center; background: var(--bg-light, #f5f7f2) !important; }
.storage-tier-note span { color: var(--text-muted-dark, #6b7b6e); }
@media (max-width: 760px) { .storage-tier-lock { grid-template-columns: 1fr; } }



/* Tenant public repository page repair pass. */
/* ── Inrep Scholar meta-bar on institution pages ─────────────────────── */
.tenant-inrep-metabar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 clamp(16px, 3vw, 48px);
  min-height: 32px;
  background: #07140d;
  font-size: 12px;
  font-weight: 500;
  position: relative;
}
.tenant-inrep-metabar-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: color .15s;
  white-space: nowrap;
}
.tenant-inrep-metabar-link:hover { color: #25c75a; }
.tenant-inrep-metabar-link svg { flex-shrink: 0; }
.tenant-inrep-metabar-sep { color: rgba(255,255,255,.25); }
.tenant-inrep-metabar-label { color: rgba(255,255,255,.35); font-size: 11px; }
.tenant-inrep-metabar-close {
  margin-left: auto;
  background: none;
  border: none;
  color: rgba(255,255,255,.3);
  font-size: 16px;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
  transition: color .12s;
}
.tenant-inrep-metabar-close:hover { color: rgba(255,255,255,.7); }
.tenant-inrep-metabar.is-hidden { display: none; }

.tenant-public-page .mkt-page {
  background: #fff;
}
.tenant-public-page .mkt-nav {
  min-height: 64px !important;
  padding-inline: clamp(18px, 4vw, 64px) !important;
}
.tenant-public-page .tenant-nav-items {
  gap: 8px !important;
}
.tenant-public-page .tenant-nav-items a,
.tenant-public-page .mkt-nav-item {
  min-height: 38px !important;
  padding: 8px 10px !important;
  font-size: 13px !important;
  font-weight: 650 !important;
}
.tenant-public-page .mkt-nav-search {
  width: clamp(220px, 22vw, 330px) !important;
  min-width: 220px !important;
  max-width: 330px !important;
}
.institution-page {
  background: #fff;
  color: var(--text-dark);
}
.institution-page .cards-section,
.institution-page .section-white,
.institution-page .mkt-light,
.institution-page .institution-rich-overview,
.institution-page .institution-quick-links,
.institution-page .institution-guidance-section,
.institution-page .institution-contact-section {
  padding: clamp(64px, 7vw, 96px) 0 !important;
}
.institution-page .section-heading {
  width: min(760px, calc(100% - 48px)) !important;
  margin: 0 auto clamp(28px, 4vw, 46px) !important;
  display: grid !important;
  justify-items: center !important;
  text-align: center !important;
}
.institution-page .section-heading .cards-section-title {
  max-width: 720px !important;
  font-size: clamp(32px, 4.2vw, 52px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.045em !important;
}
.institution-page .mkt-container,
.institution-page .mkt-container.narrow {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
}
.institution-page .stats-grid,
.institution-page .institution-rich-grid,
.institution-page .institution-quick-grid,
.institution-page .institution-guide-grid,
.institution-page .projects-public-grid,
.institution-page .audience-grid,
.institution-page .public-grid {
  width: min(1180px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
}
.institution-page .stats-section {
  padding: 36px 0 !important;
  border: 0 !important;
  background: #f4f8f4 !important;
}
.institution-page .stats-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
}
.institution-page .stat-item {
  min-height: 92px !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
}
.institution-page .stat-number {
  font-size: clamp(28px, 3vw, 42px) !important;
  line-height: 1 !important;
}
.institution-page .stat-label {
  margin-top: 8px !important;
  font-size: 11px !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.institution-page .institution-rich-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.6fr) minmax(220px, .7fr) minmax(220px, .7fr) !important;
  gap: 18px !important;
}
.institution-page .institution-rich-card,
.institution-page .public-panel,
.institution-page .institution-contact-card,
.institution-page .institution-guide-grid article,
.institution-page .institution-quick-grid a,
.institution-page .project-public-card,
.institution-page .audience-card {
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(10,31,21,.06) !important;
}
.institution-page .institution-rich-card,
.institution-page .public-panel,
.institution-page .institution-contact-card {
  padding: clamp(22px, 3vw, 32px) !important;
}
.institution-page .institution-quick-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
}
.institution-page .institution-quick-grid a {
  min-height: 150px !important;
  padding: 22px !important;
  display: grid !important;
  align-content: start !important;
  gap: 10px !important;
  color: var(--text-dark) !important;
  text-align: left !important;
}
.institution-page .institution-quick-grid a strong {
  display: block !important;
  font-size: 16px !important;
  line-height: 1.25 !important;
}
.institution-page .institution-quick-grid a span {
  display: block !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}
.institution-page .public-grid {
  display: grid !important;
  gap: 18px !important;
}
.institution-page .public-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}
.institution-page .projects-public-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
}
.institution-page .project-public-card {
  min-height: 178px !important;
  padding: 20px !important;
}
.institution-page .project-public-card h3 {
  font-size: 15px !important;
  line-height: 1.32 !important;
}
.institution-page .project-public-card p {
  line-height: 1.5 !important;
}
.institution-page .audience-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}
.institution-page .audience-card {
  min-height: 104px !important;
  padding: 18px !important;
}
.institution-page .institution-guide-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}
.institution-page .institution-guide-grid article {
  padding: 22px !important;
}
.institution-page .institution-contact-card {
  width: min(860px, 100%) !important;
  margin-inline: auto !important;
}
.institution-page .institution-contact-card p,
.institution-page .institution-contact-html {
  max-width: 720px !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  line-height: 1.65 !important;
}
.institution-page .institution-contact-strip {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.institution-page .institution-contact-strip a,
.institution-page .institution-contact-strip span {
  width: auto !important;
  max-width: 100% !important;
}
@media (max-width: 1020px) {
  .institution-page .institution-rich-grid,
  .institution-page .institution-quick-grid,
  .institution-page .institution-guide-grid,
  .institution-page .public-grid-3,
  .institution-page .projects-public-grid,
  .institution-page .audience-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .institution-page .institution-rich-card-large {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 700px) {
  .tenant-public-page .mkt-nav-search {
    display: none !important;
  }
  .institution-page .stats-grid,
  .institution-page .institution-rich-grid,
  .institution-page .institution-quick-grid,
  .institution-page .institution-guide-grid,
  .institution-page .public-grid-3,
  .institution-page .projects-public-grid,
  .institution-page .audience-grid {
    width: min(100% - 28px, 520px) !important;
    grid-template-columns: 1fr !important;
  }
  .institution-page .cards-section,
  .institution-page .section-white,
  .institution-page .mkt-light,
  .institution-page .institution-rich-overview,
  .institution-page .institution-quick-links,
  .institution-page .institution-guidance-section,
  .institution-page .institution-contact-section {
    padding-block: 52px !important;
  }
}

/* FIX60 omission cross-check dashboard structure patch */
.admin-form-card,
.admin-card {
  background: #fff;
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: var(--shadow, 0 4px 24px rgba(10,31,21,.10));
  overflow: hidden;
}

.admin-field,
.admin-form-grid > label,
.admin-panel-body > form > label {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.admin-form-card .admin-panel-body,
.admin-card-body,
.admin-panel-body {
  padding: 24px;
}

.setup-tabs,
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 20px;
  border-bottom: 1px solid var(--border-light, #e0e8e2);
  padding-bottom: 10px;
}

.setup-tab,
.admin-tab {
  min-height: 38px;
  padding: 8px 14px;
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  font-weight: 700;
  color: var(--text-dark, #0a0a0a);
}

.setup-tab[aria-selected="true"],
.admin-tab[aria-selected="true"],
.setup-tab.active,
.admin-tab.active {
  background: var(--primary, #1db954);
  color: #fff;
  border-color: var(--primary, #1db954);
}

.permissions-matrix,
.permission-matrix {
  width: 100%;
  overflow: auto;
}

.permissions-matrix table,
.permission-matrix table {
  min-width: 900px;
}

.permissions-matrix th:first-child,
.permission-matrix th:first-child,
.permissions-matrix td:first-child,
.permission-matrix td:first-child {
  position: sticky;
  left: 0;
  background: #fff;
  z-index: 2;
}


/* Emergency database/configuration error pages */
.db-driver-error {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: 32px;
  background: var(--bg-light, #f5f7f2);
}
.db-driver-card {
  width: min(780px, 100%);
  background: #fff;
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: clamp(28px, 5vw, 48px);
  box-shadow: 0 24px 70px rgba(10,31,21,.14);
}
.db-driver-card h1 {
  margin: 14px 0 12px;
  font-family: var(--font-display, sans-serif);
  font-size: clamp(30px, 5vw, 48px);
  line-height: 1.05;
  letter-spacing: -.04em;
}
.db-driver-card p,
.db-driver-card li {
  color: var(--text-muted-dark, #6b7b6e);
  font-size: 16px;
  line-height: 1.7;
}
.db-driver-card code {
  background: var(--bg-light, #f5f7f2);
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 2px 6px;
}
.db-driver-steps {
  margin: 20px 0;
  padding: 20px;
  border: 1px solid var(--border-light, #e0e8e2);
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light, #f5f7f2);
}

/* signup-choice-modal-final: styled public signup chooser */
[hidden] { display: none !important; }
.signup-choice-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: grid !important;
  place-items: center !important;
  padding: 24px !important;
}
.signup-choice-backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(8, 20, 14, .62) !important;
  backdrop-filter: blur(8px) !important;
}
.signup-choice-card {
  position: relative !important;
  z-index: 1 !important;
  width: min(640px, 100%) !important;
  border: 1px solid rgba(255,255,255,.75) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbf8 100%) !important;
  box-shadow: 0 32px 90px rgba(5, 20, 12, .28) !important;
  padding: clamp(24px, 5vw, 38px) !important;
  color: var(--text-dark, #102116) !important;
}
.signup-choice-card h2 {
  margin: 8px 0 8px !important;
  font-family: var(--font-display, inherit) !important;
  font-size: clamp(28px, 4vw, 40px) !important;
  line-height: 1.05 !important;
  letter-spacing: -.04em !important;
  color: var(--text-dark, #102116) !important;
}
.signup-choice-card p {
  margin: 0 0 22px !important;
  color: var(--muted, #607067) !important;
  line-height: 1.6 !important;
}
.signup-choice-close {
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  width: 38px !important;
  height: 38px !important;
  border: 1px solid var(--border-light, #dbe7de) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark, #102116) !important;
  font-size: 24px !important;
  line-height: 1 !important;
  cursor: pointer !important;
  display: grid !important;
  place-items: center !important;
}
.signup-choice-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}
.signup-choice-option {
  display: grid !important;
  gap: 8px !important;
  min-height: 150px !important;
  padding: 22px !important;
  border: 1px solid var(--border-light, #dbe7de) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark, #102116) !important;
  text-decoration: none !important;
  box-shadow: 0 14px 36px rgba(10, 31, 21, .08) !important;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease !important;
}
.signup-choice-option:hover,
.signup-choice-option:focus-visible {
  transform: translateY(-2px) !important;
  border-color: var(--primary, #1db954) !important;
  box-shadow: 0 20px 52px rgba(29, 185, 84, .16) !important;
  outline: none !important;
}
.signup-choice-option strong {
  font-size: 18px !important;
  line-height: 1.25 !important;
  color: var(--text-dark, #102116) !important;
}
.signup-choice-option span {
  color: var(--muted, #607067) !important;
  line-height: 1.5 !important;
  font-size: 14px !important;
}
body.signup-choice-open { overflow: hidden !important; }
@media (max-width: 640px) {
  .signup-choice-modal { align-items: end !important; padding: 14px !important; }
  .signup-choice-card { border-radius: var(--inrep-radius, 10px) !important; padding: 24px !important; }
  .signup-choice-grid { grid-template-columns: 1fr !important; }
  .signup-choice-option { min-height: auto !important; }
}
/* signup-choice-close-fix: hidden must beat modal display grid */
.signup-choice-modal[hidden] {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}


/* 20260516 admin fixes: readable logs, stable editable tables, single-active nav support */
.system-log-panel {
  padding: 0 !important;
  overflow: hidden !important;
}
.system-log-panel > .system-log-viewer,
.admin-panel.system-log-panel > pre.system-log-viewer {
  display: block !important;
  max-width: none !important;
  max-height: 70vh !important;
  margin: 0 !important;
  padding: 18px 20px !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #0d1117 !important;
  color: #e6edf3 !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace !important;
  font-size: 13px !important;
  line-height: 1.65 !important;
  white-space: pre-wrap !important;
  overflow: auto !important;
  overflow-wrap: anywhere !important;
}
.db-table-list {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 12px !important;
  padding: 24px !important;
}
.db-table-list a {
  display: grid !important;
  gap: 6px !important;
  min-width: 0 !important;
  padding: 16px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark) !important;
  text-decoration: none !important;
  box-shadow: 0 10px 26px rgba(10,31,21,.06) !important;
}
.db-table-list a:hover {
  border-color: rgba(28, 184, 86, .45) !important;
  transform: translateY(-1px) !important;
}
.db-table-list a span {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-weight: 800 !important;
}
.db-table-list a small {
  color: var(--text-muted-dark) !important;
  font-size: 12px !important;
}
.db-table-page .admin-panel {
  overflow: hidden !important;
}
.db-table-toolbar,
.db-table-search {
  width: 100% !important;
  min-width: 0 !important;
}
.db-table-search {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
.db-table-search input {
  flex: 1 1 280px !important;
  min-width: 220px !important;
}
.db-table-wrap {
  max-width: 100% !important;
  overflow: auto !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.db-table-wrap table {
  width: max-content !important;
  min-width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}
.db-table-wrap th,
.db-table-wrap td {
  max-width: 320px !important;
  vertical-align: top !important;
  background: #fff !important;
}
.db-table-wrap th {
  position: sticky !important;
  top: 0 !important;
  z-index: 2 !important;
  background: #f6fbf7 !important;
}
.db-table-wrap .db-action-col {
  position: sticky !important;
  left: 0 !important;
  z-index: 3 !important;
  width: 96px !important;
  min-width: 96px !important;
  background: #f8fcf9 !important;
  box-shadow: 1px 0 0 var(--border-light) !important;
}
.db-table-wrap tbody .db-action-col {
  background: #fff !important;
}
.db-table-cell {
  color: var(--text-dark) !important;
  line-height: 1.5 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.db-null {
  display: inline-flex !important;
  padding: 2px 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #eef3ef !important;
  color: var(--text-muted-dark) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
}
.db-pagination {
  padding: 18px 24px 24px !important;
  justify-content: flex-end !important;
}
.db-edit-form {
  padding: 24px !important;
}
.db-edit-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  gap: 18px !important;
}
.db-edit-grid label {
  display: grid !important;
  gap: 8px !important;
  min-width: 0 !important;
  padding: 14px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfefb !important;
}
.db-edit-grid label > span {
  display: flex !important;
  justify-content: space-between !important;
  gap: 8px !important;
  align-items: baseline !important;
  color: var(--text-dark) !important;
  font-weight: 800 !important;
}
.db-edit-grid label small {
  color: var(--text-muted-dark) !important;
  font-weight: 600 !important;
}
.db-edit-grid input,
.db-edit-grid textarea,
.db-edit-grid select {
  width: 100% !important;
  min-width: 0 !important;
  background: #fff !important;
  color: var(--text-dark) !important;
}
.db-edit-grid textarea {
  min-height: 120px !important;
  resize: vertical !important;
}
@media (max-width: 720px) {
  .db-table-list { grid-template-columns: 1fr !important; padding: 16px !important; }
  .db-edit-form { padding: 16px !important; }
  .db-edit-grid { grid-template-columns: 1fr !important; }
}

/* upload/subscription flow fixes */
.subscription-plan.is-selected {
  border-color: var(--primary) !important;
  box-shadow: 0 24px 70px rgba(29,185,84,.18) !important;
  outline: 2px solid rgba(29,185,84,.18);
}
.subscription-required-panel .inline-actions { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.pricing-currency-select{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:6px 12px;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:#fff;font-weight:800;color:var(--text-dark)}
.pricing-currency-select select{border:0;background:transparent;font-weight:900;color:var(--text-dark);outline:0}
.compact-form{grid-template-columns:repeat(3,minmax(0,1fr));align-items:end}
@media(max-width:780px){.compact-form{grid-template-columns:1fr}.pricing-toggle-row{flex-wrap:wrap}.pricing-currency-select{width:100%;justify-content:center}}

/* subscription/payment UX correction patch */
.subscriptions-page .admin-page-header,
.subscription-checkout-page .admin-page-header { align-items: flex-start !important; }
.subscription-cycle-tabs {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px !important;
  margin: 0 0 24px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 10px 28px rgba(10,31,21,.06) !important;
}
.subscription-cycle-tab {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 42px !important;
  padding: 9px 18px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: var(--text-dark) !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}
.subscription-cycle-tab span {
  color: var(--primary) !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
}
.subscription-cycle-tab.is-active {
  background: var(--bg-dark) !important;
  color: #fff !important;
  box-shadow: 0 10px 24px rgba(3,34,20,.18) !important;
}
.subscription-cycle-tab.is-active span { color: #bdf8cf !important; }
.subscriptions-page .subscription-filter-panel { display: none !important; }
.admin-plan-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(260px, 1fr)) !important;
  gap: 24px !important;
  align-items: stretch !important;
}
.subscription-plan {
  position: relative !important;
  overflow: hidden !important;
  padding: 28px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.subscription-plan.is-selected,
.subscription-plan.is-featured {
  border-color: var(--primary) !important;
  box-shadow: 0 24px 70px rgba(29,185,84,.16) !important;
}
.subscription-plan-head { min-height: 32px !important; align-items: flex-start !important; }
.subscription-plan .badge-green,
.subscription-checkout-page .badge-green {
  display: inline-flex !important;
  align-items: center !important;
  max-width: 100% !important;
  padding: 6px 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29,185,84,.10) !important;
  color: var(--primary-dark) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
}
.subscription-plan .badge-dark,
.subscription-checkout-page .badge-dark {
  display: inline-flex !important;
  align-items: center !important;
  padding: 6px 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-dark) !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
}
.subscription-plan h2 { font-size: clamp(21px, 2vw, 28px) !important; line-height: 1.15 !important; letter-spacing: -.035em !important; }
.subscription-plan p,
.subscription-plan .mini-muted { line-height: 1.65 !important; }
.subscription-price {
  display: flex !important;
  align-items: baseline !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  font-size: clamp(30px, 4vw, 42px) !important;
  line-height: 1.05 !important;
}
.subscription-price small { white-space: nowrap !important; }
.subscription-choice-form.single-action-form {
  display: block !important;
  margin-top: auto !important;
}
.subscription-choice-form.single-action-form .btn { width: 100% !important; }
.subscription-checkout-grid {
  display: grid !important;
  grid-template-columns: minmax(0, .95fr) minmax(340px, .75fr) !important;
  gap: 24px !important;
  align-items: start !important;
}
.checkout-selected-plan,
.checkout-payment-card { min-width: 0 !important; }
.checkout-payment-card {
  padding: 30px !important;
  position: sticky !important;
  top: 96px !important;
}
.checkout-payment-card h2 { margin: 0 0 12px !important; font-size: clamp(24px, 3vw, 36px) !important; letter-spacing: -.04em !important; }
.checkout-payment-form {
  display: grid !important;
  gap: 14px !important;
  margin-top: 22px !important;
}
.checkout-payment-form label {
  display: grid !important;
  gap: 8px !important;
  font-weight: 900 !important;
  color: var(--text-dark) !important;
}
.checkout-payment-form select {
  width: 100% !important;
  min-height: 48px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark) !important;
  font-weight: 800 !important;
}
.checkout-amount-preview {
  display: grid !important;
  gap: 4px !important;
  padding: 16px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
}
.checkout-amount-preview span,
.checkout-amount-preview small { color: var(--text-muted-dark) !important; font-weight: 700 !important; }
.checkout-amount-preview strong { color: var(--text-dark) !important; font-size: 26px !important; letter-spacing: -.03em !important; }
.checkout-payment-form .btn { width: 100% !important; min-height: 54px !important; justify-content: center !important; }
@media (max-width: 1180px) {
  .admin-plan-grid { grid-template-columns: repeat(2, minmax(260px, 1fr)) !important; }
  .subscription-checkout-grid { grid-template-columns: 1fr !important; }
  .checkout-payment-card { position: static !important; }
}
@media (max-width: 760px) {
  .admin-plan-grid { grid-template-columns: 1fr !important; }
  .subscription-cycle-tabs { width: 100% !important; justify-content: stretch !important; }
  .subscription-cycle-tab { flex: 1 !important; justify-content: center !important; }
  .subscription-plan { padding: 22px !important; }
}


/* 20260519 subscription logic and UI cleanup */
.subscription-flow-clean .admin-page-header{align-items:flex-start!important}
.subscription-plan-grid-clean{display:grid!important;grid-template-columns:repeat(3,minmax(280px,1fr))!important;gap:24px!important;align-items:stretch!important;margin-top:18px!important;margin-bottom:26px!important}
.subscription-flow-clean .subscription-plan{display:flex!important;flex-direction:column!important;gap:16px!important;min-width:0!important;padding:28px!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;box-shadow:0 20px 60px rgba(10,31,21,.08)!important;overflow:hidden!important}
.subscription-flow-clean .subscription-plan.is-selected,.subscription-flow-clean .subscription-plan.is-featured{border-color:var(--primary)!important;box-shadow:0 24px 70px rgba(29,185,84,.14)!important;outline:0!important}
.subscription-plan-head{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;gap:10px!important;min-height:32px!important}
.tier-badge{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:auto!important;max-width:100%!important;padding:7px 11px!important;border-radius:var(--inrep-radius, 10px) !important;font-size:11px!important;line-height:1!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.055em!important;white-space:nowrap!important;text-decoration:none!important}
.tier-badge-soft{background:rgba(29,185,84,.11)!important;color:var(--primary-dark)!important;border:1px solid rgba(29,185,84,.18)!important}
.tier-badge-dark{background:var(--bg-dark)!important;color:#fff!important;border:1px solid rgba(255,255,255,.08)!important}
.subscription-flow-clean .subscription-plan h2{font-size:clamp(22px,2vw,29px)!important;line-height:1.12!important;letter-spacing:-.04em!important;margin:0!important;color:var(--text-dark)!important}
.subscription-flow-clean .subscription-plan p{margin:0!important;color:var(--muted)!important;line-height:1.62!important}
.subscription-flow-clean .subscription-price{display:flex!important;align-items:baseline!important;flex-wrap:wrap!important;gap:5px!important;font-size:clamp(30px,4vw,42px)!important;line-height:1.05!important;letter-spacing:-.045em!important;color:var(--text-dark)!important;max-width:100%!important;overflow-wrap:anywhere!important}
.subscription-flow-clean .subscription-price small{font-size:13px!important;letter-spacing:0!important;color:var(--muted)!important;white-space:nowrap!important}
.subscription-flow-clean .subscription-plan ul{display:grid!important;gap:10px!important;margin:0!important;padding:0!important;list-style:none!important}
.subscription-flow-clean .subscription-plan li{position:relative!important;padding-left:25px!important;font-size:14px!important;line-height:1.45!important;color:var(--text-dark)!important}
.subscription-flow-clean .subscription-plan li:before{content:'\2713'!important;position:absolute!important;left:0!important;top:0!important;color:var(--primary)!important;font-weight:900!important}
.subscription-flow-clean .subscription-choice-form.single-action-form{display:block!important;margin-top:auto!important}
.subscription-flow-clean .subscription-choice-form.single-action-form .btn{width:100%!important;justify-content:center!important}
.subscription-cycle-tabs{display:inline-flex!important;align-items:center!important;gap:8px!important;padding:6px!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;box-shadow:0 12px 30px rgba(10,31,21,.07)!important;margin:0 0 24px!important}
.subscription-cycle-tab{display:inline-flex!important;align-items:center!important;gap:8px!important;min-height:42px!important;padding:9px 18px!important;border-radius:var(--inrep-radius, 10px) !important;color:var(--text-dark)!important;font-weight:900!important;text-decoration:none!important}
.subscription-cycle-tab.is-active{background:var(--bg-dark)!important;color:#fff!important}.subscription-cycle-tab span{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.05em!important;color:var(--primary)!important}.subscription-cycle-tab.is-active span{color:#bdf8cf!important}
.subscription-checkout-grid{display:grid!important;grid-template-columns:minmax(0,.95fr) minmax(340px,.75fr)!important;gap:24px!important;align-items:start!important}.checkout-payment-card{padding:30px!important;position:sticky!important;top:96px!important}.checkout-payment-form{display:grid!important;gap:14px!important;margin-top:22px!important}.checkout-payment-form .btn{width:100%!important;min-height:54px!important;justify-content:center!important}.checkout-amount-preview{display:grid!important;gap:4px!important;padding:16px!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:var(--bg-light)!important}.checkout-amount-preview strong{color:var(--text-dark)!important;font-size:26px!important;letter-spacing:-.03em!important}
@media(max-width:1180px){.subscription-plan-grid-clean{grid-template-columns:repeat(2,minmax(260px,1fr))!important}.subscription-checkout-grid{grid-template-columns:1fr!important}.checkout-payment-card{position:static!important}}@media(max-width:760px){.subscription-plan-grid-clean{grid-template-columns:1fr!important}.subscription-cycle-tabs{width:100%!important;justify-content:stretch!important}.subscription-cycle-tab{flex:1!important;justify-content:center!important}.subscription-flow-clean .subscription-plan{padding:22px!important}}

/* Super admin plan pricing manager */
.plan-pricing-manager-panel .admin-panel-header{align-items:flex-start;gap:16px}.plan-pricing-table td{vertical-align:middle}.pricing-input{width:150px;max-width:100%;height:42px;border:1px solid var(--border,#dfe7e2);border-radius:var(--inrep-radius, 10px) !important;padding:0 12px;background:#fff;color:var(--ink,#07110b);font-weight:800}.pricing-input:focus{outline:2px solid rgba(33,181,89,.18);border-color:var(--brand,#20b559)}.plan-pricing-manager-form .form-actions{display:flex;justify-content:flex-end;margin-top:16px}.plan-pricing-manager-form .tier-badge{text-transform:none}
@media(max-width:760px){.pricing-input{width:100%}.plan-pricing-manager-form .form-actions{justify-content:stretch}.plan-pricing-manager-form .form-actions .btn{width:100%}}

/* pricing currency admin control */
.pricing-currency-control{display:grid;gap:8px;max-width:260px;margin:0 0 16px;font-weight:800;color:var(--text-dark,#06130a)}
.pricing-currency-control select{height:44px;border:1px solid var(--border,#dfe7e2);border-radius:var(--inrep-radius, 10px) !important;padding:0 12px;background:#fff;color:var(--ink,#07110b);font-weight:800}
.pricing-currency-control select:focus{outline:2px solid rgba(33,181,89,.18);border-color:var(--brand,#20b559)}


/* Final subscription/payment simplification */
.subscription-final-flow .subscription-pay-trigger{width:100%;justify-content:center;margin-top:auto!important}
.subscription-final-flow .subscription-plan{min-height:100%;display:flex!important;flex-direction:column!important}
.subscription-final-flow .subscription-plan ul{margin-bottom:14px!important}
.payment-choice-open{overflow:hidden}
.payment-choice-modal[hidden]{display:none!important}
.payment-choice-modal{position:fixed;inset:0;z-index:10050;display:grid;place-items:center;padding:20px}
.payment-choice-backdrop{position:absolute;inset:0;background:rgba(7,18,15,.62);backdrop-filter:blur(5px)}
.payment-choice-dialog{position:relative;z-index:1;width:min(520px,100%);background:#fff;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 28px 90px rgba(5,18,13,.32);padding:28px;display:grid;gap:16px;color:var(--text-dark)}
.payment-choice-dialog h2{margin:0;font-size:26px;letter-spacing:-.03em;color:var(--text-dark)}
.payment-choice-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:var(--inrep-radius, 10px) !important;border:1px solid var(--border-light);background:#fff;color:var(--text-dark);font-size:24px;line-height:1;cursor:pointer}
.payment-choice-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.payment-choice-actions form{margin:0}.payment-choice-actions .btn{width:100%;justify-content:center}.pricing-tier-private-note strong{font-size:30px!important}.pricing-tier-private-note small{color:var(--muted)!important}
@media(max-width:640px){.payment-choice-actions{grid-template-columns:1fr}.payment-choice-dialog{padding:22px}.payment-choice-close{top:10px;right:10px}}

/* 2026-05-08 admin UI correction: screenshot defects */
body.admin-fullscreen {
  height: 100dvh !important;
  min-height: 100dvh !important;
  overflow: hidden !important;
}
.admin-shell {
  height: 100dvh !important;
  min-height: 100dvh !important;
  display: grid !important;
  grid-template-columns: var(--admin-sidebar-width-expanded) minmax(0, 1fr) !important;
  grid-template-rows: 64px auto minmax(0, 1fr) !important;
  grid-template-areas:
    "sidebar topbar"
    "sidebar banner"
    "sidebar main" !important;
  overflow: hidden !important;
}
body.admin-sidebar-collapsed .admin-shell {
  grid-template-columns: var(--admin-sidebar-width-collapsed) minmax(0, 1fr) !important;
}
.admin-sidebar {
  grid-area: sidebar !important;
  height: 100dvh !important;
  max-height: 100dvh !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
}
.admin-sidebar-header {
  top: 0 !important;
  margin-bottom: 8px !important;
  padding-bottom: 10px !important;
}
.admin-sidebar-link {
  min-height: 38px !important;
  height: auto !important;
  line-height: 1.15 !important;
}
.admin-topbar {
  grid-area: topbar !important;
  grid-column: auto !important;
  min-width: 0 !important;
  overflow: visible !important;
}
.admin-readiness-banner {
  grid-area: banner !important;
  grid-column: auto !important;
}
.admin-readiness-banner:empty,
.admin-readiness-banner[hidden] {
  display: none !important;
}
.admin-main {
  grid-area: main !important;
  grid-column: auto !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 24px 28px 36px !important;
}
.admin-breadcrumbs {
  margin: 0 auto 22px !important;
  max-width: var(--admin-max-content, 1480px) !important;
}
.admin-page {
  display: grid !important;
  gap: 22px !important;
  width: 100% !important;
  max-width: var(--admin-max-content, 1480px) !important;
  margin: 0 auto !important;
}
.admin-page-header {
  margin: 0 !important;
  padding: 0 !important;
  align-items: flex-start !important;
}
.admin-page-title {
  margin: 0 0 8px !important;
}
.admin-page-subtitle {
  margin: 0 !important;
}
.admin-main .admin-page > .admin-panel,
.admin-main .admin-page > .admin-grid,
.admin-main .admin-page > .admin-plan-grid,
.admin-main .admin-page > .subscription-cycle-tabs {
  margin-top: 0 !important;
}
.subscriptions-page,
.subscription-final-flow,
.institution-detail-page {
  gap: 22px !important;
}
.subscriptions-page .admin-page-header,
.subscription-final-flow .admin-page-header {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.mobile-wizard-nav {
  display: none !important;
}
@media (max-width: 779px) {
  .mobile-wizard-nav {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    overflow-x: auto !important;
    grid-column: 1 / -1 !important;
    padding-bottom: 6px !important;
    margin-bottom: 4px !important;
  }
  .mobile-wizard-nav button {
    flex: 0 0 auto !important;
    min-height: 36px !important;
    padding: 7px 12px !important;
    border: 1px solid var(--border-light) !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff !important;
    color: var(--text-dark) !important;
    font-weight: 800 !important;
    font-size: 12px !important;
  }
  .mobile-wizard-nav button.active {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
  }
}
.storage-panel[data-storage-section]:not(.is-active) {
  display: none !important;
}
.storage-panel[hidden] {
  display: none !important;
}
.admin-panel.warning-panel .panel-head,
.storage-tier-lock-panel .panel-head {
  margin: 0 !important;
}
.institution-edit-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.institution-switch {
  min-height: 46px !important;
  padding: 10px 12px !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
}
.institution-detail-table code {
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
  color: var(--text-dark) !important;
}
.detail-stack {
  display: grid !important;
  gap: 10px !important;
}
.detail-row {
  display: grid !important;
  grid-template-columns: minmax(120px, .4fr) minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--border-light) !important;
}
.detail-row:last-child {
  border-bottom: 0 !important;
}
.detail-row span {
  color: var(--text-muted-dark) !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
}
.detail-row strong {
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  color: var(--text-dark) !important;
}
.smtp-test-inline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
}
.smtp-test-inline input {
  width: min(280px, 38vw) !important;
  min-height: 42px !important;
}
@media (max-width: 1023px) {
  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell,
  body:not(.admin-sidebar-collapsed) .admin-shell {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: 60px auto minmax(0, 1fr) !important;
    grid-template-areas:
      "topbar"
      "banner"
      "main" !important;
  }
  .admin-sidebar {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(320px, 86vw) !important;
    transform: translateX(-105%) !important;
    z-index: 220 !important;
  }
  body.admin-sidebar-open .admin-sidebar {
    transform: translateX(0) !important;
  }
  .admin-sidebar-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 210 !important;
  }
  .admin-main {
    padding: 18px 14px 28px !important;
  }
  .institution-edit-grid,
  .institution-summary-grid,
  .admin-grid-5 {
    grid-template-columns: 1fr !important;
  }
  .email-header-actions,
  .smtp-test-inline {
    width: 100% !important;
  }
  .smtp-test-inline input,
  .smtp-test-inline button {
    width: 100% !important;
  }
}
@media (max-width: 640px) {
  .admin-topbar-title {
    max-width: 42vw !important;
  }
  .admin-main {
    padding: 14px 12px 24px !important;
  }
  .detail-row {
    grid-template-columns: 1fr !important;
  }
}

/* 20260508 department/document queue full-page arrangement */
.department-queue-page {
  max-width: 1520px !important;
}
.queue-page-hero {
  align-items: center !important;
  padding: 0 !important;
  gap: 18px !important;
}
.queue-page-hero .eyebrow {
  margin: 0 0 8px !important;
  color: var(--primary, #20b559) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
}
.queue-hero-actions form,
.queue-claim-form,
.queue-decision-form {
  margin: 0 !important;
}
.queue-metrics {
  margin: 0 !important;
}
.department-queue-panel {
  padding: 0 !important;
  overflow: hidden !important;
}
.queue-panel-header {
  padding: 22px 24px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--border-light) !important;
  align-items: center !important;
}
.queue-panel-header h2 {
  margin: 0 0 6px !important;
  font-size: 20px !important;
}
.queue-panel-header p {
  margin: 0 !important;
  color: var(--text-muted-dark) !important;
}
.department-queue-table-wrap {
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: none !important;
}
.department-queue-table {
  min-width: 1180px !important;
  table-layout: fixed !important;
}
.department-queue-table th,
.department-queue-table td {
  vertical-align: top !important;
}
.department-queue-table th:nth-child(1) { width: 34% !important; }
.department-queue-table th:nth-child(2) { width: 12% !important; }
.department-queue-table th:nth-child(3) { width: 12% !important; }
.department-queue-table th:nth-child(4) { width: 10% !important; }
.department-queue-table th:nth-child(5) { width: 10% !important; }
.department-queue-table th:nth-child(6) { width: 10% !important; }
.department-queue-table th:nth-child(7) { width: 22% !important; }
.queue-record-cell {
  min-width: 0 !important;
}
.queue-record-cell strong {
  display: block !important;
  margin-bottom: 6px !important;
  color: var(--text-dark) !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
}
.queue-record-cell > span {
  display: block !important;
  color: var(--text-muted-dark) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}
.queue-record-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-top: 10px !important;
}
.queue-record-meta em {
  max-width: 100% !important;
  padding: 5px 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light) !important;
  color: var(--text-muted-dark) !important;
  font-size: 11px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.queue-block-note {
  margin-top: 10px !important;
  padding: 9px 10px !important;
  border: 1px solid #f3d289 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff8df !important;
  color: #7a5200 !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
}
.metadata-score {
  display: grid !important;
  gap: 3px !important;
}
.metadata-score strong {
  font-size: 16px !important;
  color: var(--text-dark) !important;
}
.metadata-score span {
  font-size: 11px !important;
  font-weight: 800 !important;
  color: var(--text-muted-dark) !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
.metadata-score.bad strong,
.department-queue-table tr.is-blocked .queue-record-cell strong {
  color: #9f5b00 !important;
}
.queue-action-cell {
  min-width: 260px !important;
}
.queue-action-cell,
.queue-decision-form {
  display: grid !important;
  gap: 10px !important;
}
.queue-decision-form textarea {
  width: 100% !important;
  min-height: 74px !important;
  resize: vertical !important;
  border: 1px solid var(--border-light) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 10px 12px !important;
  background: #fff !important;
  color: var(--text-dark) !important;
  font: inherit !important;
  font-size: 13px !important;
}
.queue-action-buttons {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
.queue-action-buttons .btn,
.queue-claim-form .btn {
  width: 100% !important;
  justify-content: center !important;
}
.queue-empty-state {
  margin: 22px !important;
}
@media (max-width: 900px) {
  .queue-page-hero,
  .queue-panel-header {
    align-items: stretch !important;
  }
  .queue-hero-actions,
  .queue-hero-actions form,
  .queue-hero-actions .btn {
    width: 100% !important;
  }
  .department-queue-table {
    min-width: 1040px !important;
  }
}

/* 2026-05-08 production workflow cleanup */
.admin-page { padding-bottom: 56px; }
.compact-page-header { min-height: 0 !important; padding: 28px 0 22px !important; margin-bottom: 16px !important; }
.compact-page-header .admin-page-title { margin-bottom: 8px !important; }
.compact-panel { margin-bottom: 18px !important; }
.compact-grid { gap: 12px !important; }
.compact-metrics { margin: 10px 0 18px !important; }
.subscriptions-page.subscription-final-flow .admin-page-header { min-height: 0 !important; padding: 28px 0 18px !important; margin-bottom: 16px !important; }
.subscriptions-page .current-plan-panel,
.subscriptions-page .subscription-required-panel,
.subscriptions-page .subscription-cycle-tabs { margin-top: 16px !important; margin-bottom: 16px !important; }
.subscription-plan-grid-clean { align-items: stretch !important; margin-top: 12px !important; }
.subscription-plan-grid-clean .subscription-plan { min-height: 0 !important; }

.project-upload-page .tier-rule-panel { margin-bottom: 16px !important; }
.project-upload-wizard { padding: 0 !important; overflow: hidden !important; }
.form-stepper { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0; border-bottom: 1px solid var(--border-light); background: #fbfdfb; }
.form-stepper button { appearance: none; border: 0; border-right: 1px solid var(--border-light); background: transparent; min-height: 64px; padding: 14px 10px; display: flex; align-items: center; justify-content: center; gap: 9px; color: var(--muted); font-weight: 850; cursor: pointer; }
.form-stepper button:last-child { border-right: 0; }
.form-stepper button span { width: 24px; height: 24px; border-radius: var(--inrep-radius, 10px) !important; display: inline-grid; place-items: center; background: #e9f3ed; color: var(--primary-dark); font-size: 12px; }
.form-stepper button.is-active { background: #fff; color: var(--text-dark); box-shadow: inset 0 -3px 0 var(--primary); }
.form-stepper button.is-complete span { background: var(--primary); color: #fff; }
.upload-step { display: none; padding: 24px; }
.upload-step.is-active { display: block; }
.upload-step .form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.upload-step .full, .upload-step .span-full { grid-column: 1 / -1; }
.wizard-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border-light); }
.review-summary-card { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light); padding: 18px; display: grid; gap: 4px; }
.review-summary-card strong { font-size: 18px; color: var(--text-dark); }
.review-summary-card span, .review-summary-card small { color: var(--muted); }
.review-summary-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.review-summary-item { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: #fff; padding: 13px 14px; min-width: 0; }
.review-summary-item span { display: block; color: var(--muted); font-size: 12px; font-weight: 800; margin-bottom: 5px; text-transform: uppercase; letter-spacing: .05em; }
.review-summary-item strong { display: block; color: var(--text-dark); overflow-wrap: anywhere; line-height: 1.45; }
.project-upload-page .storage-panel { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: #fff; padding: 18px; }
.project-upload-page .storage-tier-lock { display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 18px; align-items: stretch; }
.project-upload-page .storage-tier-note { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: var(--bg-light); padding: 16px; display: grid; gap: 6px; align-content: center; }

.clean-queue-table { min-width: 980px !important; table-layout: fixed !important; }
.clean-queue-table th:nth-child(1) { width: 30% !important; }
.clean-queue-table th:nth-child(2) { width: 15% !important; }
.clean-queue-table th:nth-child(3) { width: 15% !important; }
.clean-queue-table th:nth-child(4) { width: 12% !important; }
.clean-queue-table th:nth-child(5) { width: 13% !important; }
.clean-queue-table th:nth-child(6) { width: 10% !important; }
.clean-queue-table th:nth-child(7) { width: 90px !important; }
.queue-title-cell strong { display: block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-dark); }
.queue-title-cell small { display: block; margin-top: 4px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.clean-queue-table .table-actions { justify-content: flex-end !important; }
.department-review-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 18px; align-items: start; }
.review-side-panel { position: sticky; top: 92px; }
.detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.detail-grid div, .long-detail-block { border: 1px solid var(--border-light); border-radius: var(--inrep-radius, 10px) !important; background: #fff; padding: 14px; min-width: 0; }
.detail-grid span, .long-detail-block span { display: block; color: var(--muted); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px; }
.detail-grid strong, .long-detail-block p { margin: 0; color: var(--text-dark); overflow-wrap: anywhere; line-height: 1.55; }
.long-detail-block { margin-top: 12px; }
.review-action-form { display: grid; gap: 12px; margin-top: 14px; }
.review-action-form textarea { min-height: 120px; }
.review-decision-buttons { display: grid; gap: 10px; }
.queue-pass-note { border: 1px solid rgba(29,185,84,.24); background: rgba(29,185,84,.08); color: var(--primary-dark); border-radius: var(--inrep-radius, 10px) !important; padding: 12px; font-weight: 800; }

@media (max-width: 980px) {
  .form-stepper { grid-template-columns: 1fr; }
  .form-stepper button { justify-content: flex-start; border-right: 0; border-bottom: 1px solid var(--border-light); min-height: 48px; }
  .upload-step .form-grid, .review-summary-grid, .project-upload-page .storage-tier-lock, .department-review-layout, .detail-grid { grid-template-columns: 1fr; }
  .review-side-panel { position: static; }
}
@media (max-width: 640px) {
  .upload-step { padding: 18px; }
  .wizard-actions { flex-direction: column-reverse; }
  .wizard-actions .btn { width: 100%; }
}

/* Action feedback: every redirect result should be visible, dismissible and not hidden in page content. */
.action-alert {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
  position: sticky !important;
  top: 14px !important;
  z-index: 70 !important;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .12) !important;
  transform: translateY(-4px);
  opacity: .98;
}
.action-alert span { overflow-wrap: anywhere; line-height: 1.45; }
.action-alert button {
  border: 0;
  background: transparent;
  color: inherit;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 0 0 0 8px;
  opacity: .75;
}
.action-alert button:hover { opacity: 1; }
.single-payment-action { grid-template-columns: 1fr !important; }
.single-payment-action form, .single-payment-action .btn { width: 100%; }

/* Global action notifications and loaders */
.admin-toast-stack {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 9999;
  display: grid;
  gap: 10px;
  width: min(420px, calc(100vw - 32px));
  pointer-events: none;
}
.admin-toast {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #dbe5ef;
  background: #fff;
  color: #102033;
  box-shadow: 0 18px 48px rgba(15,23,42,.16);
  font-weight: 700;
  line-height: 1.45;
}
.admin-toast.success { border-color: #86efac; background: #f0fdf4; color: #14532d; }
.admin-toast.error { border-color: #fca5a5; background: #fef2f2; color: #991b1b; }
.admin-toast.warning { border-color: #facc15; background: #fefce8; color: #854d0e; }
.admin-toast.info { border-color: #93c5fd; background: #eff6ff; color: #1e3a8a; }
.admin-toast button {
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  padding: 0;
}
button.is-loading,
.btn.is-loading {
  opacity: .72;
  cursor: wait !important;
  pointer-events: none;
}
button.is-loading::after,
.btn.is-loading::after {
  content: "";
  display: inline-block;
  width: .8em;
  height: .8em;
  margin-left: .55em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: var(--inrep-radius, 10px) !important;
  vertical-align: -.1em;
  animation: action-spin .75s linear infinite;
}
@keyframes action-spin { to { transform: rotate(360deg); } }
.email-center-simple .admin-page-header { align-items: flex-start; }
.smtp-test-inline { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.smtp-test-inline input { min-width: 260px; }
.smtp-diagnostics-simple { margin-bottom: 20px; }
.flutterwave-only-panel .payment-diagnostics { margin-bottom: 18px; }
@media (max-width: 720px) {
  .admin-toast-stack { top: 10px; right: 10px; left: 10px; width: auto; }
  .smtp-test-inline, .smtp-test-inline input, .smtp-test-inline .btn { width: 100%; }
}

/* Upload + payment production simplification */
.direct-flutterwave-checkout-form{margin-top:auto;display:flex}
.direct-flutterwave-checkout-form .btn{width:100%;justify-content:center}
.metadata-quality-panel{display:grid;gap:12px;padding:16px;border:1px solid #dbeafe;background:#f8fbff;border-radius:var(--inrep-radius, 10px) !important;margin-bottom:16px}
.metadata-quality-panel strong{color:#0f172a}
.metadata-quality-checks{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin:0;padding:0;list-style:none}
.metadata-quality-checks li{padding:8px 10px;border-radius:var(--inrep-radius, 10px) !important;background:#fff;border:1px solid #e2e8f0;font-size:12px;font-weight:700;color:#64748b}
.metadata-quality-checks li.is-complete{background:#ecfdf5;border-color:#bbf7d0;color:#047857}
.metadata-quality-score{height:10px;background:#e2e8f0;border-radius:var(--inrep-radius, 10px) !important;overflow:hidden}
.metadata-quality-score span{display:block;height:100%;width:0;background:linear-gradient(90deg,#0ea5e9,#10b981);transition:width .2s ease}
.project-upload-wizard .upload-step{display:none}
.project-upload-wizard .upload-step.is-active{display:block}
.project-upload-wizard .form-stepper{position:sticky;top:0;z-index:4;background:#fff;border-bottom:1px solid #e2e8f0;padding-bottom:10px;margin-bottom:18px}
.project-upload-wizard .wizard-actions{position:sticky;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.84),#fff);border-top:1px solid #e2e8f0;padding-top:14px;margin-top:18px}
.upload-storage-lock-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:14px;border:1px solid #e2e8f0;border-radius:var(--inrep-radius, 10px) !important;background:#f8fafc;margin-bottom:14px}
.upload-storage-lock-card strong{display:block;color:#0f172a}
@media(max-width:760px){.upload-storage-lock-card{display:block}.project-upload-wizard .form-stepper{position:static}.metadata-quality-checks{grid-template-columns:1fr}}

/* 2026-05-08 UI repair: admin spacing, card padding, grid stability, public chatbot */
.admin-main,
.admin-page {
  min-width: 0 !important;
  overflow-x: hidden !important;
}
.admin-page {
  display: grid !important;
  gap: 22px !important;
  padding-bottom: 44px !important;
}
.admin-page-header {
  margin: 0 0 4px !important;
  gap: 18px !important;
  align-items: flex-start !important;
}
.admin-page-title {
  margin: 0 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.045em !important;
}
.admin-page-subtitle {
  margin: 10px 0 0 !important;
  max-width: 880px !important;
  line-height: 1.6 !important;
}
.admin-grid {
  width: 100% !important;
  min-width: 0 !important;
  align-items: stretch !important;
}
.admin-grid > *,
.admin-card,
.admin-panel,
.metric-card {
  min-width: 0 !important;
}
.admin-card,
.admin-panel,
.metric-card {
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #dfe8e2 !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(10, 31, 21, .08) !important;
}
.admin-card,
.admin-panel {
  padding: clamp(22px, 2.2vw, 34px) !important;
  overflow: visible !important;
}
.admin-card > h2,
.admin-panel > h2,
.admin-card > h3,
.admin-panel > h3 {
  margin: 0 0 18px !important;
  color: #06140d !important;
  line-height: 1.18 !important;
  letter-spacing: -0.035em !important;
  overflow-wrap: anywhere !important;
}
.admin-card .clean-list,
.admin-panel .clean-list {
  display: grid !important;
  gap: 11px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.admin-card .clean-list li,
.admin-panel .clean-list li {
  margin: 0 !important;
  line-height: 1.45 !important;
  overflow-wrap: anywhere !important;
}
.admin-table-wrap {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.admin-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}
.admin-table th,
.admin-table td {
  vertical-align: top !important;
  padding: 16px 18px !important;
  line-height: 1.45 !important;
  overflow-wrap: anywhere !important;
}
.admin-main .form-grid,
.admin-main form.form-grid,
.admin-card .form-grid,
.admin-panel .form-grid {
  gap: 18px 22px !important;
  align-items: start !important;
}
.admin-main label,
.admin-card label,
.admin-panel label {
  min-width: 0 !important;
}
.admin-main input,
.admin-main select,
.admin-main textarea,
.admin-card input,
.admin-card select,
.admin-card textarea,
.admin-panel input,
.admin-panel select,
.admin-panel textarea {
  max-width: 100% !important;
  min-width: 0 !important;
}
.inline-check {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  min-height: 44px !important;
  line-height: 1.35 !important;
}
.inline-check input[type="checkbox"] {
  width: 22px !important;
  height: 22px !important;
  flex: 0 0 auto !important;
}
.admin-grid-3 > .admin-card .form-grid,
.admin-grid-3 > .admin-panel .form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.admin-grid-3 > .admin-card .form-grid > .span-full,
.admin-grid-3 > .admin-panel .form-grid > .span-full,
.admin-grid-3 > .admin-card .form-grid > button,
.admin-grid-3 > .admin-panel .form-grid > button {
  grid-column: 1 / -1 !important;
}
.metric-card {
  padding: clamp(20px, 2vw, 28px) !important;
  overflow: hidden !important;
}
.metric-card span,
.metric-card small {
  line-height: 1.45 !important;
  overflow-wrap: anywhere !important;
}
.metric-card strong {
  line-height: 1.08 !important;
  overflow-wrap: anywhere !important;
}
.status-badge.approved,
.status-badge.active,
.status-badge.verified {
  background: #dcfce7 !important;
  color: #047857 !important;
  border-color: #86efac !important;
}
.status-badge.pending,
.status-badge.email_pending,
.status-badge.draft {
  background: #fef9c3 !important;
  color: #854d0e !important;
  border-color: #fde68a !important;
}
.status-badge.rejected,
.status-badge.suspended,
.status-badge.failed {
  background: #fee2e2 !important;
  color: #991b1b !important;
  border-color: #fecaca !important;
}
@media (max-width: 1180px) {
  .admin-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .admin-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 760px) {
  .admin-page { gap: 16px !important; }
  .admin-page-header,
  .admin-actions { flex-direction: column !important; align-items: stretch !important; }
  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4,
  .admin-grid-5,
  .admin-grid-3 > .admin-card .form-grid,
  .admin-grid-3 > .admin-panel .form-grid {
    grid-template-columns: 1fr !important;
  }
  .admin-card,
  .admin-panel { padding: 20px !important; border-radius: var(--inrep-radius, 10px) !important; }
  .admin-table th,
  .admin-table td { padding: 14px !important; }
}
.site-chatbot {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 9998;
  font-family: var(--font-body, system-ui, sans-serif);
}
.site-chatbot-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: var(--inrep-radius, 10px) !important;
  min-height: 44px;
  padding: 10px 18px;
  background: #0a6b3b;
  color: #fff;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .01em;
  white-space: nowrap;
  box-shadow: 0 18px 44px rgba(10,107,59,.26);
  cursor: pointer;
  transition: transform .18s cubic-bezier(.32,.72,0,1), box-shadow .2s ease, background .2s ease;
}
.site-chatbot-toggle:hover { background: #0d7e44; transform: translateY(-1px); box-shadow: 0 22px 48px rgba(10,107,59,.32); }
.site-chatbot-toggle:active { transform: translateY(0); }
.site-chatbot-toggle > svg { flex: none; width: 18px; height: 18px; }
.site-chatbot-toggle > span { display: inline-block; }
.site-chatbot-panel {
  position: absolute;
  right: 0;
  bottom: 62px;
  width: min(380px, calc(100vw - 32px));
  max-height: min(620px, calc(100vh - 120px));
  display: grid;
  grid-template-rows: auto minmax(220px, 1fr) auto;
  overflow: hidden;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #dbe7dd;
  background: #fff;
  box-shadow: 0 28px 80px rgba(2, 6, 23, .22);
}
.site-chatbot-panel[hidden] { display: none !important; }
.site-chatbot-panel header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 18px;
  background: #062d1c;
  color: #fff;
}
.site-chatbot-panel header button {
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 24px;
  cursor: pointer;
}
.site-chatbot-messages {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 16px;
  overflow: auto;
  background: #f6faf7;
}
.site-chatbot-message {
  max-width: 88%;
  padding: 11px 13px;
  border-radius: var(--inrep-radius, 10px) !important;
  line-height: 1.45;
  font-size: 14px;
  overflow-wrap: anywhere;
}
.site-chatbot-message.bot {
  justify-self: start;
  background: #fff;
  border: 1px solid #dbe7dd;
  color: #102018;
}
.site-chatbot-message.user {
  justify-self: end;
  background: #0a6b3b;
  color: #fff;
}
.site-chatbot-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  padding: 12px;
  border-top: 1px solid #dbe7dd;
  background: #fff;
}
.site-chatbot-form input {
  width: 100%;
  min-height: 44px;
  border: 1px solid #dbe7dd;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 0 14px;
}
.site-chatbot-form button {
  border: 0;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 0 16px;
  background: #0a6b3b;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}
.site-chatbot-form button:disabled { opacity: .65; cursor: wait; }
@media (max-width: 640px) {
  .site-chatbot { right: 14px; bottom: 14px; }
  .site-chatbot-panel { width: calc(100vw - 28px); bottom: 58px; }
}

/* Registration password validation controls */
.register-center .password-control{position:relative;display:flex;align-items:center;width:100%;gap:8px}
.register-center .password-control input{width:100%;padding-right:76px!important}
.register-center .password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:0;background:#eef7f1;color:#064b2d;border-radius:var(--inrep-radius, 10px) !important;padding:7px 12px;font-weight:800;cursor:pointer;line-height:1}
.register-center .password-toggle:hover{background:#d9f4e3}
.register-center .password-help{display:block;margin-top:7px;color:#7a5a00;font-size:12px;font-weight:700;line-height:1.35}
.register-center .password-help.ok{color:#087a3d}
.register-center button[disabled]{opacity:.68;cursor:wait}

/* Registration password validation hardening */
.password-help.ok{color:#078b43;font-weight:700}
.password-help.error{color:#b42318;font-weight:700}
button.is-disabled,button:disabled{cursor:not-allowed;opacity:.62;filter:saturate(.65)}

/* Strong password live checklist */
.register-center .password-checklist {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: grid;
  gap: 6px;
}
.register-center .password-checklist li {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #7a5a00;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}
.register-center .password-checklist li::before {
  content: '\00D7';
  width: 18px;
  height: 18px;
  border-radius: var(--inrep-radius, 10px) !important;
  display: inline-grid;
  place-items: center;
  background: #fff4e5;
  color: #b42318;
  font-size: 13px;
  font-weight: 900;
  flex: 0 0 18px;
}
.register-center .password-checklist li.passed {
  color: #087a3d;
}
.register-center .password-checklist li.passed::before {
  content: '\2713';
  background: #dff8e8;
  color: #087a3d;
}
.register-center .password-checklist li.failed {
  color: #b42318;
}
.register-center .password-match-help.error,
.register-center .password-help.error {
  color: #b42318;
}
.register-center .password-match-help.ok,
.register-center .password-help.ok {
  color: #087a3d;
}
.register-center button.is-disabled,
.register-center button[aria-disabled="true"] {
  opacity: .58;
  cursor: not-allowed;
}
.register-center button.is-loading {
  cursor: wait;
}


/* FINAL registration layout fix: consistent aligned inputs on student/university signup */
.auth-center.register-center {
  width: min(1080px, calc(100vw - 32px)) !important;
  max-width: 1080px !important;
}
.register-center form.auth-card.signup-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  align-items: start !important;
  gap: 18px 22px !important;
}
.register-center form.auth-card.signup-form-grid > label,
.register-center form.auth-card.signup-form-grid > .field-group {
  min-width: 0 !important;
  align-self: start !important;
}
.register-center label,
.register-center .field-group {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}
.register-center input,
.register-center select,
.register-center textarea,
.register-center .password-control {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.register-center select {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.register-center .password-control input {
  min-width: 0 !important;
}
.register-center .field-error-text {
  display: none;
  color: #b42318;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}
.register-center .is-invalid > .field-error-text,
.register-center label.is-invalid > .field-error-text {
  display: block;
}
.register-center label.is-invalid input,
.register-center label.is-invalid select,
.register-center label.is-invalid textarea {
  border-color: #d92d20 !important;
  box-shadow: 0 0 0 3px rgba(217,45,32,.12) !important;
}
.register-center label.is-valid input,
.register-center label.is-valid select,
.register-center label.is-valid textarea {
  border-color: #12b76a !important;
}
.register-center .form-live-summary {
  grid-column: 1 / -1 !important;
  border: 1px solid #fedf89;
  background: #fffaeb;
  color: #7a5a00;
  padding: 12px 14px;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 13px;
  font-weight: 800;
}
.register-center .form-live-summary.ok {
  border-color: #abefc6;
  background: #ecfdf3;
  color: #087a3d;
}
@media (max-width: 820px) {
  .auth-center.register-center {
    width: min(100vw - 20px, 720px) !important;
    padding: 16px !important;
  }
  .register-center form.auth-card.signup-form-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 18px !important;
  }
}

/* Final consolidated auth/admin layout hardening - 2026-05-09 */
.auth-center,
.register-center {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 32px 0 56px;
}
.signup-form-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px 20px !important;
  align-items: start !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.signup-form-grid label,
.admin-form-grid label,
.public-form label {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
  min-width: 0 !important;
  margin: 0 !important;
}
.signup-form-grid input,
.signup-form-grid select,
.signup-form-grid textarea,
.admin-form-grid input,
.admin-form-grid select,
.admin-form-grid textarea,
.public-form input,
.public-form select,
.public-form textarea {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 46px !important;
  box-sizing: border-box !important;
}
.signup-form-grid .span-full,
.admin-form-grid .span-full,
.span-full {
  grid-column: 1 / -1 !important;
}
.form-section-title {
  margin-top: 8px !important;
  padding: 10px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fafc !important;
  color: #0f172a !important;
  font-weight: 800 !important;
  letter-spacing: .01em !important;
}
.password-control {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 8px !important;
  align-items: center !important;
}
.password-control input { min-width: 0 !important; }
.password-toggle {
  min-height: 46px !important;
  padding: 0 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #cbd5e1 !important;
  background: #fff !important;
  color: #0f172a !important;
  font-weight: 700 !important;
  cursor: pointer !important;
}
.password-checklist {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 6px 12px !important;
  padding: 10px 12px !important;
  margin: 0 !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fafc !important;
  list-style: none !important;
}
.password-checklist li {
  font-size: .86rem !important;
  color: #b91c1c !important;
}
.password-checklist li::before { content: '\2022 '; }
.password-checklist li.passed { color: #15803d !important; }
.password-help,
.field-error-text,
.form-live-summary {
  font-size: .86rem !important;
  line-height: 1.35 !important;
}
.field-error-text { color: #b91c1c !important; }
label.is-invalid input,
label.is-invalid select,
label.is-invalid textarea { border-color: #dc2626 !important; box-shadow: 0 0 0 3px rgba(220, 38, 38, .08) !important; }
label.is-valid input,
label.is-valid select,
label.is-valid textarea { border-color: #16a34a !important; }
.form-live-summary {
  grid-column: 1 / -1 !important;
  padding: 10px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff7ed !important;
  color: #9a3412 !important;
  border: 1px solid #fed7aa !important;
}
.form-live-summary.ok {
  background: #f0fdf4 !important;
  color: #166534 !important;
  border-color: #bbf7d0 !important;
}
.admin-table-wrap {
  width: 100% !important;
  overflow-x: auto !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.admin-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  table-layout: auto !important;
}
.admin-table th,
.admin-table td {
  vertical-align: middle !important;
  padding: 12px 14px !important;
  max-width: 420px !important;
  overflow-wrap: anywhere !important;
}
.admin-panel,
.admin-card,
.policy-card,
.coverage-card {
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.admin-panel-body,
.admin-card-body,
.policy-card-body {
  padding: 18px !important;
}
@media (max-width: 820px) {
  .auth-center,
  .register-center { width: min(100% - 20px, 100%) !important; padding-top: 20px !important; }
  .signup-form-grid,
  .admin-form-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .password-checklist { grid-template-columns: 1fr !important; }
}


/* =====================================================================
   PUBLIC PROJECT DETAIL - FINAL VISUAL QA FIX
   Fixes record page contrast, spacing, metadata cards, citation controls,
   sticky access panel, mobile layout, and prevents marketing dark-section
   text rules from leaking into the repository record page.
   ===================================================================== */
.public-body .project-detail.project-detail-rebuilt {
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(48px, 7vw, 92px) 0;
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(280px, 320px);
  gap: 28px;
  align-items: start;
}

.public-body .project-detail-main,
.public-body .project-detail-side {
  background: #fff;
  border: 1px solid #dfe9e2;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 18px 50px rgba(10, 31, 21, .10);
}

.public-body .project-detail-main {
  padding: clamp(26px, 4vw, 44px);
  min-width: 0;
}

.public-body .project-detail-side {
  padding: 24px;
  min-width: 0;
}

.public-body .project-access-panel {
  position: sticky;
  top: 96px;
}

.public-body .project-breadcrumb,
.public-body .project-meta-strip,
.public-body .record-impact-grid {
  color: #526255;
}

.public-body .project-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  font-size: 13px;
}

.public-body .record-impact-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0 12px;
  font-size: 12px;
  line-height: 1.35;
}

.public-body .record-impact-grid span,
.public-body .project-status-line .pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 6px 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f2f7f2;
  border: 1px solid #dfe9e2;
  color: #425146;
  white-space: nowrap;
}

.public-body .record-impact-grid strong {
  color: #0a0a0a;
  margin-right: 3px;
}

.public-body .project-status-line {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 16px;
}

.public-body .project-status-line .pill.ok {
  color: #0f7a3b;
  background: #dcfce7;
  border-color: #bbf7d0;
  font-weight: 700;
}

.public-body .project-detail-main h1 {
  margin: 10px 0 12px;
  color: #07110b;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.12;
  letter-spacing: -.04em;
  max-width: 920px;
}

.public-body .project-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-bottom: 8px;
  padding-bottom: 18px;
  border-bottom: 1px solid #e5eee7;
  font-size: 14px;
}

.public-body .project-meta-strip span + span::before {
  content: "\2022";
  margin-right: 10px;
  color: #8aa08f;
}

.public-body .project-section {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid #e5eee7;
}

.public-body .project-section h2 {
  margin: 0 0 16px;
  color: #07110b;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.2;
  letter-spacing: -.025em;
}

.public-body .project-section h3 {
  margin: 14px 0 8px;
  color: #07110b;
  font-size: 16px;
  line-height: 1.35;
}

.public-body .project-section p,
.public-body .project-abstract-text,
.public-body .project-detail-rebuilt .feature-showcase-desc {
  color: #26352a !important;
  font-size: 16px;
  line-height: 1.78;
  margin: 0;
  max-width: none;
  opacity: 1 !important;
}

.public-body .project-abstract-text {
  background: #fbfdfb;
  border: 1px solid #eef4ee;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 18px;
}

.public-body .metadata-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.public-body .metadata-grid div {
  min-width: 0;
  background: #f5f8f3;
  border: 1px solid #e4ece4;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 14px 16px;
}

.public-body .metadata-grid dt {
  margin: 0 0 6px;
  color: #69786c;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.public-body .metadata-grid dd {
  margin: 0;
  color: #122016;
  font-size: 14px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.public-body .section-inline-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.public-body .section-inline-head h2 {
  margin: 0;
}

.public-body .inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
}

.public-body .btn.tiny,
.public-body .btn.small,
.public-body .project-side-actions .btn,
.public-body .request-access-form .btn,
.public-body .review-form .btn {
  border-radius: var(--inrep-radius, 10px) !important;
  min-height: 34px;
  padding: 8px 13px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.public-body .citation-box {
  width: 100%;
  min-height: 104px;
  margin: 8px 0 12px;
  padding: 14px 16px;
  color: #122016;
  background: #fbfdfb;
  border: 1px solid #dfe9e2;
  border-radius: var(--inrep-radius, 10px) !important;
  resize: vertical;
  font: 14px/1.55 var(--font-body);
}

.public-body .empty-state.compact {
  min-height: auto;
  padding: 28px;
  color: #526255;
  background: #f8faf7;
  border: 1px dashed #d6e2d8;
  border-radius: var(--inrep-radius, 10px) !important;
  text-align: center;
}

.public-body .public-form.review-form,
.public-body .public-form.request-access-form {
  margin-top: 20px;
  display: grid;
  gap: 12px;
}

.public-body .form-grid-compact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px;
  gap: 12px;
}

.public-body .public-form input,
.public-body .public-form select,
.public-body .public-form textarea,
.public-body .request-access-form input,
.public-body .request-access-form textarea {
  width: 100%;
  min-height: 42px;
  border: 1px solid #dfe9e2;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: #122016;
  padding: 10px 12px;
  font: 14px/1.4 var(--font-body);
  box-shadow: none;
}

.public-body .public-form textarea,
.public-body .request-access-form textarea {
  min-height: 92px;
  resize: vertical;
}

.public-body .project-detail-side h2 {
  margin: 0 0 12px;
  color: #07110b;
  font-size: 22px;
  line-height: 1.2;
}

.public-body .project-detail-side h3 {
  margin: 14px 0 8px;
  color: #07110b;
  font-size: 15px;
}

.public-body .project-detail-side p,
.public-body .side-note {
  color: #334437;
  font-size: 14px;
  line-height: 1.55;
}

.public-body .project-side-actions {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.public-body .project-side-actions form,
.public-body .project-side-actions button,
.public-body .project-side-actions a {
  width: 100%;
  justify-content: center;
  text-align: center;
}

.public-body .side-note {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid #e5eee7;
}

.public-body .side-note strong {
  display: inline-block;
  margin-bottom: 3px;
  color: #07110b;
}

.public-body .related-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.public-body .related-card {
  display: grid;
  gap: 8px;
  padding: 16px;
  background: #fbfdfb;
  border: 1px solid #dfe9e2;
  border-radius: var(--inrep-radius, 10px) !important;
  color: #122016;
}

.public-body .related-card small {
  color: #526255;
}

@media (max-width: 980px) {
  .public-body .project-detail.project-detail-rebuilt {
    grid-template-columns: 1fr;
    width: min(760px, calc(100% - 32px));
    padding: 36px 0;
  }
  .public-body .project-access-panel {
    position: static;
  }
}

@media (max-width: 640px) {
  .public-body .project-detail.project-detail-rebuilt {
    width: calc(100% - 24px);
    gap: 16px;
  }
  .public-body .project-detail-main,
  .public-body .project-detail-side {
    padding: 20px;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .public-body .metadata-grid,
  .public-body .form-grid-compact,
  .public-body .related-grid {
    grid-template-columns: 1fr;
  }
  .public-body .project-meta-strip span + span::before {
    content: none;
    margin: 0;
  }
  .public-body .record-impact-grid span,
  .public-body .project-status-line .pill {
    white-space: normal;
  }
}

/* Upload work type visibility fix */
.work-type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-top:16px}
.work-type-card{display:flex;flex-direction:column;gap:6px;padding:16px;border:1px solid var(--border-light,#e2e8f0);border-radius:var(--inrep-radius, 10px) !important;background:#fff;color:inherit;text-decoration:none;box-shadow:0 10px 24px rgba(15,23,42,.05);transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.work-type-card:hover{transform:translateY(-2px);border-color:var(--primary,#16a34a);box-shadow:0 16px 34px rgba(15,23,42,.1)}
.work-type-card strong{font-size:15px;color:var(--text-dark,#0f172a)}
.work-type-card span{font-size:13px;color:var(--muted,#64748b);line-height:1.45}
.project-upload-page select[name="document_type"],.submission-upload-page select[name="document_type"]{min-height:48px;font-weight:750;border-color:#b7d9c2;background:#fbfffc}
.project-upload-page label.full select[name="document_type"],.submission-upload-page label.full select[name="document_type"]{width:100%}
@media(max-width:760px){.work-type-grid{grid-template-columns:1fr}.project-upload-page .form-grid,.submission-upload-page .form-grid{grid-template-columns:1fr!important}}

/* Phase 4.1 workflow hardening: clean tables, bulk bars, CSV guidance, support tickets, librarian actions */
.table-bulk-bar{
  display:flex!important;align-items:center!important;gap:10px!important;flex-wrap:wrap!important;
  padding:12px!important;margin:0 0 14px!important;border:1px solid #bfdbfe!important;border-radius:var(--inrep-radius, 10px) !important;
  background:#eff6ff!important;color:#0f172a!important;
}
.table-bulk-bar[hidden]{display:none!important}
.table-bulk-bar select,.table-bulk-bar input{width:auto!important;min-width:190px!important;max-width:320px!important;margin:0!important}
.support-ticket-table td,.library-review-table td,.records-table td,.users-admin-table td{vertical-align:top!important}
.support-ticket-subject{min-width:340px!important;max-width:560px!important}
.support-ticket-subject small{display:block;color:var(--muted)!important;line-height:1.45!important;margin:4px 0!important}
.support-filters.admin-filter-bar{display:grid!important;grid-template-columns:2fr 1fr 1fr auto!important;gap:12px!important;align-items:end!important;margin-bottom:16px!important}
.review-help-box{display:flex!important;gap:8px!important;align-items:flex-start!important}
.review-action-stack{display:grid!important;gap:8px!important;min-width:300px!important}
.review-action-stack form{display:flex!important;align-items:center!important;gap:6px!important;flex-wrap:wrap!important;margin:0!important;padding:0!important;background:transparent!important;border:0!important;box-shadow:none!important}
.review-mini-form input[type="date"]{width:145px!important;min-width:145px!important;height:34px!important;min-height:34px!important;padding:5px 8px!important}
.review-mini-form input[name="note"]{width:180px!important;min-width:160px!important;height:34px!important;min-height:34px!important;padding:5px 8px!important}
.ai-review-cell{min-width:220px!important;max-width:280px!important}
.ai-review-cell small{display:block;color:var(--muted)!important;line-height:1.45!important;margin-top:4px!important}
.library-record-title{min-width:280px!important;max-width:440px!important}
.csv-columns-panel .admin-panel-header{align-items:flex-start!important;margin-bottom:14px!important}
.csv-columns-table code{display:inline-flex!important;align-items:center!important;white-space:nowrap!important;background:#f1f5f9!important;border:1px solid #e2e8f0!important;border-radius:var(--inrep-radius, 10px) !important;padding:4px 8px!important;font-weight:800!important;color:#0f172a!important}
.csv-columns-table td:nth-child(3){min-width:360px!important}
.csv-sample-box{margin-top:16px!important;display:grid!important;gap:8px!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:#f8fafc!important;padding:14px!important;overflow:hidden!important}
.csv-sample-box pre{margin:0!important;overflow-x:auto!important;max-width:100%!important;background:#0f172a!important;color:#e2e8f0!important;border-radius:var(--inrep-radius, 10px) !important;padding:12px!important}
.csv-sample-box code{white-space:pre!important;color:inherit!important;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important}
.csv-help-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important;gap:12px!important;margin-top:14px!important}
.csv-help-grid article{border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:#f8fafc!important;padding:12px!important}
.csv-help-grid strong{display:block!important;margin-bottom:4px!important}
.csv-help-grid small{display:block!important;color:var(--muted)!important;line-height:1.45!important}
.inline-check{display:flex!important;align-items:center!important;gap:8px!important}
.inline-check input[type="checkbox"]{width:auto!important;min-height:auto!important}
@media(max-width:900px){
  .support-filters.admin-filter-bar{grid-template-columns:1fr!important}
  .table-bulk-bar select,.table-bulk-bar input{width:100%!important;max-width:100%!important}
  .review-action-stack{min-width:240px!important}
}

/* Phase 4.2 final table layout fixes */
.support-ticket-panel .admin-table-wrap,
.csv-columns-panel .admin-table-wrap,
.librarian-review-page .admin-table-wrap{
  width:100%!important;
  overflow-x:auto!important;
  border-radius:var(--inrep-radius, 10px) !important;
}
.support-ticket-table,
.library-review-table{
  width:100%!important;
  min-width:980px!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  table-layout:auto!important;
}
.support-ticket-table th,
.support-ticket-table td,
.library-review-table th,
.library-review-table td{
  padding:12px 14px!important;
  border-bottom:1px solid #e6eee8!important;
  white-space:normal!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
}
.support-ticket-table th,
.library-review-table th,
.csv-columns-table th{
  background:#f8fbf9!important;
  color:#314139!important;
  font-size:12px!important;
  text-transform:uppercase!important;
  letter-spacing:.04em!important;
}
.support-ticket-table td:first-child,
.library-review-table td:first-child{width:42px!important;min-width:42px!important;max-width:42px!important}
.support-ticket-table .btn,
.library-review-table .btn{white-space:nowrap!important}
.csv-columns-table{
  width:100%!important;
  min-width:820px!important;
  border-collapse:separate!important;
  border-spacing:0!important;
}
.csv-columns-table th,
.csv-columns-table td{
  padding:12px 14px!important;
  border-bottom:1px solid #e6eee8!important;
  vertical-align:top!important;
  white-space:normal!important;
  line-height:1.45!important;
}
.csv-columns-table td:first-child{width:190px!important;white-space:nowrap!important}
.csv-columns-table td:nth-child(2){width:140px!important}
.csv-columns-table td:nth-child(4){max-width:320px!important}
.csv-columns-table .status-badge,
.csv-columns-table .pill{display:inline-flex!important;margin:0!important;white-space:nowrap!important}
.csv-columns-panel{overflow:hidden!important}
.csv-sample-box strong{font-size:13px!important;color:#334155!important;text-transform:uppercase!important;letter-spacing:.04em!important}
.review-actions-cell{min-width:340px!important}
.review-action-stack .btn.tiny{height:34px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important}
@media(max-width:760px){
  .support-ticket-table,.library-review-table,.csv-columns-table{min-width:860px!important}
  .support-ticket-panel,.csv-columns-panel,.librarian-review-page .admin-panel{padding:16px!important}
}

/* Phase 4.3 table pagination, bulk-action and support detail hardening */
.admin-pagination{
  display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:10px!important;
  margin:16px 0 0!important;padding:10px 0!important;color:#475569!important;font-weight:700!important;
}
.admin-pagination .btn.disabled{opacity:.45!important;pointer-events:none!important;cursor:not-allowed!important}
.admin-pagination span{display:inline-flex!important;align-items:center!important;min-height:30px!important;padding:0 8px!important}
.client-table-pagination{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:8px!important;margin:12px 0 0!important;flex-wrap:wrap!important}
.client-table-pagination button{border:1px solid #d7e2da!important;background:#fff!important;color:#0f172a!important;border-radius:var(--inrep-radius, 10px) !important;padding:7px 11px!important;font-weight:800!important;cursor:pointer!important}
.client-table-pagination button.is-active{background:#063b25!important;color:#fff!important;border-color:#063b25!important}
.client-table-pagination button:disabled{opacity:.45!important;cursor:not-allowed!important}
.clean-ticket-detail{display:grid!important;grid-template-columns:minmax(0,1fr) 380px!important;gap:18px!important;align-items:start!important}
.ticket-detail-card,.ticket-status-card{min-width:0!important;overflow:hidden!important}
.ticket-message-box{white-space:pre-wrap!important;line-height:1.75!important;background:#f8fafc!important;border:1px solid #e2e8f0!important;border-radius:var(--inrep-radius, 10px) !important;padding:18px!important;color:#0f172a!important;overflow-wrap:anywhere!important;font-size:14px!important}
.ticket-kv-clean{display:grid!important;gap:0!important;margin:0!important}
.ticket-kv-clean div{display:grid!important;grid-template-columns:115px minmax(0,1fr)!important;gap:12px!important;padding:11px 0!important;border-bottom:1px solid #e8f0ea!important;align-items:start!important}
.ticket-kv-clean dt{margin:0!important;color:#64748b!important;font-weight:800!important;font-size:12px!important;text-transform:uppercase!important;letter-spacing:.04em!important}
.ticket-kv-clean dd{margin:0!important;color:#0f172a!important;font-weight:750!important;overflow-wrap:anywhere!important;min-width:0!important;text-align:right!important}
.ticket-update-form{margin-top:18px!important;padding-top:14px!important;border-top:1px solid #e8f0ea!important}
.access-requests-table td{vertical-align:top!important}
.access-requests-table td:nth-child(2){min-width:260px!important;max-width:420px!important}
.access-requests-table td:nth-child(4){min-width:240px!important;max-width:420px!important;overflow-wrap:anywhere!important}
.filter-actions{display:flex!important;align-items:end!important;gap:8px!important;flex-wrap:wrap!important}
@media(max-width:1050px){.clean-ticket-detail{grid-template-columns:1fr!important}.ticket-kv-clean dd{text-align:left!important}}
@media(max-width:720px){.ticket-kv-clean div{grid-template-columns:1fr!important;gap:4px!important}.admin-pagination,.client-table-pagination{justify-content:flex-start!important}.support-filters.admin-filter-bar,.admin-filter-bar{grid-template-columns:1fr!important}}

/* Phase 4.4 clean ZIP + CSV guide */
.clean-csv-guide{padding:28px!important;border-radius:var(--inrep-radius, 10px) !important;overflow:hidden!important;background:#fff!important}
.clean-csv-guide .csv-guide-header{display:flex!important;justify-content:space-between!important;gap:16px!important;margin-bottom:18px!important;padding-bottom:14px!important;border-bottom:1px solid #e6eee8!important}
.clean-csv-guide .csv-guide-header .eyebrow{margin:0 0 8px!important;color:#047857!important;font-size:12px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.08em!important}
.clean-csv-guide .csv-guide-header h2{margin:0!important;font-size:26px!important;line-height:1.15!important;color:#0f1f16!important}
.clean-csv-guide .csv-guide-header p:not(.eyebrow){margin:8px 0 0!important;max-width:820px!important;color:#5b6e61!important;line-height:1.55!important}
.csv-guide-table-wrap{border:1px solid #dfe9e3!important;border-radius:var(--inrep-radius, 10px) !important;overflow-x:auto!important;background:#fff!important;box-shadow:0 10px 28px rgba(15,31,22,.04)!important}
.csv-guide-table{width:100%!important;min-width:920px!important;border-collapse:separate!important;border-spacing:0!important;table-layout:auto!important;margin:0!important}
.csv-guide-table th{padding:13px 16px!important;background:#f4faf6!important;color:#314139!important;font-size:12px!important;letter-spacing:.06em!important;text-transform:uppercase!important;text-align:left!important;border-bottom:1px solid #dfe9e3!important;white-space:nowrap!important}
.csv-guide-table td{padding:15px 16px!important;border-bottom:1px solid #edf3ef!important;vertical-align:top!important;color:#14251a!important;line-height:1.55!important;background:#fff!important}
.csv-guide-table tr:nth-child(even) td{background:#fbfdfc!important}
.csv-guide-table tr:last-child td{border-bottom:0!important}
.csv-guide-table td:first-child{width:190px!important}
.csv-guide-table td:nth-child(2){width:150px!important}
.csv-guide-table td:nth-child(4){width:240px!important;color:#475569!important}
.csv-guide-table code{display:inline-flex!important;align-items:center!important;max-width:100%!important;white-space:nowrap!important;overflow-wrap:normal!important;background:#ecfdf5!important;border:1px solid #cfe8d9!important;color:#064e3b!important;border-radius:var(--inrep-radius, 10px) !important;padding:5px 9px!important;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important;font-size:13px!important;font-weight:900!important}
.csv-guide-badge{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:26px!important;border-radius:var(--inrep-radius, 10px) !important;padding:4px 10px!important;font-size:12px!important;font-weight:900!important;white-space:nowrap!important;border:1px solid transparent!important}
.csv-guide-badge.required{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
.csv-guide-badge.zip{background:#fef3c7!important;color:#92400e!important;border-color:#fde68a!important}
.csv-guide-badge.optional{background:#e8f5ed!important;color:#166534!important;border-color:#bbf7d0!important}
.csv-example-text{display:block!important;color:#475569!important;overflow-wrap:anywhere!important}
.clean-csv-guide .csv-guide-samples{display:grid!important;grid-template-columns:1fr!important;gap:14px!important;margin-top:18px!important}
.clean-csv-guide .csv-guide-codebox{position:relative!important;display:grid!important;grid-template-columns:1fr auto!important;gap:10px 12px!important;align-items:center!important;border:1px solid #dfe9e3!important;border-radius:var(--inrep-radius, 10px) !important;background:#f8fafc!important;padding:14px!important;overflow:hidden!important}
.clean-csv-guide .csv-codebox-title{font-size:13px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.05em!important;color:#334155!important}
.clean-csv-guide .csv-guide-codebox pre{grid-column:1/-1!important;margin:0!important;max-width:100%!important;overflow-x:auto!important;background:#0f172a!important;color:#e2e8f0!important;border-radius:var(--inrep-radius, 10px) !important;padding:14px 16px!important;line-height:1.7!important;white-space:pre!important}
.clean-csv-guide .csv-guide-codebox code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important;font-size:13px!important;color:inherit!important;white-space:pre!important}
.clean-csv-guide .csv-guide-notes{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:14px!important;margin-top:18px!important}
.clean-csv-guide .csv-guide-notes article{border:1px solid #dfe9e3!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfc!important;padding:16px!important;min-width:0!important}
.clean-csv-guide .csv-guide-notes h3{margin:0 0 8px!important;font-size:15px!important;line-height:1.25!important;color:#0f1f16!important}
.clean-csv-guide .csv-guide-notes p{margin:0!important;color:#475569!important;line-height:1.55!important}
.clean-csv-guide .csv-guide-notes code{background:#ecfdf5!important;border:1px solid #cfe8d9!important;color:#064e3b!important;border-radius:var(--inrep-radius, 10px) !important;padding:2px 6px!important;font-weight:900!important}
@media(max-width:980px){.clean-csv-guide .csv-guide-notes{grid-template-columns:1fr!important}.clean-csv-guide{padding:18px!important}.csv-guide-table{min-width:820px!important}}

/* Phase 4.5 clean submission link generator */
.submission-link-generator{max-width:1480px!important;margin:0 auto!important;padding-bottom:32px!important}
.submission-link-hero{align-items:flex-start!important;gap:18px!important;margin-bottom:18px!important;padding-top:10px!important}
.submission-link-hero .admin-page-title{font-size:clamp(32px,4vw,56px)!important;line-height:.98!important;letter-spacing:-.055em!important;margin:0 0 10px!important;max-width:900px!important}
.submission-link-hero .admin-page-subtitle{max-width:960px!important;font-size:17px!important;line-height:1.6!important;color:#556b5c!important;margin:0!important}
.submission-link-generator .eyebrow{margin:0 0 8px!important;color:#06a34f!important;font-size:12px!important;font-weight:950!important;text-transform:uppercase!important;letter-spacing:.11em!important}
.submission-link-layout{display:grid!important;grid-template-columns:minmax(0,1fr) 360px!important;gap:18px!important;align-items:start!important}
.submission-primary-card,.submission-generator-card,.submission-usage-panel{border-radius:var(--inrep-radius, 10px) !important;border:1px solid #dfe9e3!important;background:#fff!important;box-shadow:0 18px 50px rgba(15,31,22,.06)!important}
.submission-primary-card{padding:26px!important;display:grid!important;gap:22px!important;min-width:0!important}
.card-heading-row{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;gap:16px!important;padding-bottom:16px!important;border-bottom:1px solid #e8f0ea!important}
.card-heading-row h2,.submission-generator-card h2{margin:0!important;color:#0f1f16!important;font-size:24px!important;line-height:1.2!important;letter-spacing:-.03em!important}
.submission-url-box{display:grid!important;gap:9px!important}
.submission-url-box label{margin:0!important;color:#425446!important;font-size:13px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.055em!important}
.submission-copy-control{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:10px!important;align-items:center!important}
.submission-copy-control input{width:100%!important;height:58px!important;border:1px solid #d8e5dd!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfc!important;color:#07140c!important;padding:0 18px!important;font-size:18px!important;font-weight:900!important;line-height:1.2!important;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)!important}
.submission-copy-control .btn{height:58px!important;border-radius:var(--inrep-radius, 10px) !important;padding:0 24px!important;font-size:15px!important;font-weight:950!important;white-space:nowrap!important}
.submission-link-generator .copy-feedback{min-height:20px!important;color:#047857!important;font-size:13px!important;font-weight:850!important;margin:0!important}
.submission-share-grid{display:grid!important;grid-template-columns:320px minmax(0,1fr)!important;gap:18px!important;align-items:stretch!important}
.submission-qr-card,.submission-message-card{border:1px solid #dfe9e3!important;border-radius:var(--inrep-radius, 10px) !important;background:#f8faf9!important;padding:18px!important;min-width:0!important}
.submission-qr-card{display:grid!important;gap:14px!important;align-content:start!important;text-align:center!important;justify-items:center!important}
.submission-qr-card .qr-box{width:212px!important;height:212px!important;border-radius:var(--inrep-radius, 10px) !important;padding:16px!important;background:#fff!important;border:1px solid #d8e5dd!important;box-shadow:0 10px 28px rgba(15,31,22,.08)!important;display:flex!important;align-items:center!important;justify-content:center!important}
.submission-qr-card img{width:180px!important;height:180px!important;display:block!important;image-rendering:auto!important}
.submission-qr-card h3,.submission-message-card h3,.submission-usage-panel h3{margin:0 0 6px!important;color:#0f1f16!important;font-size:17px!important;line-height:1.3!important;font-weight:950!important}
.submission-qr-card p,.submission-message-card p,.submission-usage-panel p{margin:0!important;color:#54685a!important;line-height:1.55!important;font-size:14px!important}
.submission-message-card{display:grid!important;grid-template-rows:auto 1fr!important;gap:14px!important}
.message-card-head{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;gap:14px!important}
.message-card-head .btn{height:40px!important;border-radius:var(--inrep-radius, 10px) !important;white-space:nowrap!important;font-weight:900!important}
.submission-message-card textarea{width:100%!important;min-height:190px!important;resize:vertical!important;border:1px solid #d8e5dd!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;padding:16px!important;font-size:15px!important;line-height:1.65!important;color:#0f172a!important;font-weight:750!important;overflow-wrap:anywhere!important}
.submission-generator-card{padding:22px!important;position:sticky!important;top:86px!important}
.submission-generator-card form{display:grid!important;gap:15px!important;margin:0!important}
.submission-generator-card label{display:grid!important;gap:7px!important;margin:0!important;color:#26362b!important;font-weight:900!important;font-size:13px!important}
.submission-generator-card input,.submission-generator-card select{width:100%!important;height:48px!important;border:1px solid #d8e5dd!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;padding:0 13px!important;color:#0f172a!important;font-weight:800!important}
.submission-generator-card .form-help{margin:0 0 3px!important;color:#64756a!important;line-height:1.5!important;font-size:14px!important}
.submission-generator-card .btn.full{width:100%!important;justify-content:center!important;height:50px!important;border-radius:var(--inrep-radius, 10px) !important;font-weight:950!important;margin-top:4px!important}
.submission-empty{display:grid!important;gap:7px!important;padding:18px!important;border:1px dashed #bad4c4!important;border-radius:var(--inrep-radius, 10px) !important;background:#f4faf6!important;color:#475569!important;line-height:1.55!important}
.submission-empty strong{color:#0f1f16!important;font-size:16px!important}
.submission-empty code{background:#ecfdf5!important;border:1px solid #cfe8d9!important;border-radius:var(--inrep-radius, 10px) !important;padding:2px 6px!important;color:#064e3b!important;font-weight:900!important}
.submission-usage-panel{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:0!important;margin-top:18px!important;padding:0!important;overflow:hidden!important}
.submission-usage-panel>div{padding:22px!important;border-right:1px solid #e8f0ea!important;min-width:0!important}
.submission-usage-panel>div:last-child{border-right:0!important}
@media(max-width:1180px){.submission-link-layout{grid-template-columns:1fr!important}.submission-generator-card{position:static!important}.submission-share-grid{grid-template-columns:280px minmax(0,1fr)!important}}
@media(max-width:820px){.submission-primary-card{padding:18px!important}.submission-copy-control{grid-template-columns:1fr!important}.submission-copy-control .btn{width:100%!important}.submission-share-grid{grid-template-columns:1fr!important}.submission-qr-card{text-align:left!important;justify-items:start!important}.message-card-head{display:grid!important}.submission-usage-panel{grid-template-columns:1fr!important}.submission-usage-panel>div{border-right:0!important;border-bottom:1px solid #e8f0ea!important}.submission-usage-panel>div:last-child{border-bottom:0!important}.submission-link-hero .admin-page-title{font-size:34px!important}}

.purpose-lock-notice{
    margin-top:12px;
    padding:12px 14px;
    border:1px solid #bbf7d0;
    background:#f0fdf4;
    color:#064e3b;
    border-radius:var(--inrep-radius, 10px) !important;
    font-size:14px;
    line-height:1.5;
}
.locked-purpose-box{
    border:1px solid #bbf7d0;
    background:#f0fdf4;
    border-radius:var(--inrep-radius, 10px) !important;
    padding:16px;
    display:grid;
    gap:6px;
}
.locked-purpose-box strong{
    font-size:20px;
    color:#064e3b;
}

/* Phase 4.6 bulk actions + pagination polish */
.table-bulk-bar{
    display:flex!important;
    align-items:center!important;
    gap:10px!important;
    flex-wrap:wrap!important;
    width:100%!important;
    margin:0 0 14px!important;
    padding:12px 14px!important;
    border:1px solid #dfe9e3!important;
    border-radius:var(--inrep-radius, 10px) !important;
    background:linear-gradient(180deg,#ffffff 0%,#f8faf9 100%)!important;
    box-shadow:0 10px 28px rgba(15,31,22,.06)!important;
}
.table-bulk-bar strong{display:inline-flex!important;align-items:center!important;gap:6px!important;color:#0f1f16!important;font-weight:950!important;white-space:nowrap!important}
.table-bulk-bar input,.table-bulk-bar select{height:38px!important;border:1px solid #d8e5dd!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;color:#0f172a!important;padding:0 12px!important;font-weight:750!important;min-width:230px!important;max-width:360px!important;margin:0!important}
.table-bulk-bar .btn{height:38px!important;border-radius:var(--inrep-radius, 10px) !important;font-weight:900!important;white-space:nowrap!important;box-shadow:none!important}
.table-select-line{display:flex!important;align-items:center!important;gap:10px!important;margin:0 0 12px!important;color:#425446!important;font-size:13px!important;font-weight:850!important}
.inline-check input[type="checkbox"],.admin-table input[type="checkbox"]{width:17px!important;height:17px!important;accent-color:#16a34a!important;cursor:pointer!important}
.admin-table th:first-child,.admin-table td:first-child{width:42px!important;text-align:center!important}
.admin-pagination{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:8px!important;margin-top:14px!important;flex-wrap:wrap!important;color:#475569!important;font-weight:850!important}
.admin-pagination .btn{height:34px!important;border-radius:var(--inrep-radius, 10px) !important;padding:0 12px!important}
.admin-pagination .btn.disabled,.admin-pagination .disabled{opacity:.45!important;pointer-events:none!important;cursor:not-allowed!important}
.admin-pagination span{display:inline-flex!important;align-items:center!important;min-height:34px!important;padding:0 8px!important;color:#475569!important}
.admin-table-wrap + .admin-pagination,.review-list + .admin-pagination{margin-top:16px!important}
@media(max-width:780px){.table-bulk-bar{align-items:stretch!important}.table-bulk-bar .btn,.table-bulk-bar input,.table-bulk-bar select{width:100%!important;max-width:100%!important}.admin-pagination{justify-content:flex-start!important}}

/* Admin email OTP login flow */
.auth-otp-card{max-width:460px!important;gap:14px!important}.auth-kicker{margin:0;color:var(--primary-dark);font-weight:900;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.auth-note{margin:0 0 4px;color:var(--muted);line-height:1.55}.otp-form input[name="otp"]{text-align:center;font-size:24px;font-weight:900;letter-spacing:8px}.auth-resend-form{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:12px}.auth-resend-form .btn{width:auto!important;min-height:42px}.security-setting-panel{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:20px!important;margin-bottom:16px!important;border:1px solid rgba(29,185,84,.22)!important;background:linear-gradient(135deg,#fff,#f3fbf6)!important}.security-setting-copy{max-width:760px}.security-setting-copy h2{margin:4px 0 8px!important;color:var(--text-dark)!important}.security-setting-copy p{margin:0!important;color:var(--muted)!important;line-height:1.55!important}.security-toggle-form{display:flex!important;align-items:center!important;gap:10px!important;flex-wrap:wrap!important;justify-content:flex-end!important}.security-toggle-form .btn{white-space:nowrap!important}@media(max-width:760px){.security-setting-panel{align-items:flex-start!important;flex-direction:column!important}.security-toggle-form{width:100%!important;justify-content:flex-start!important}.auth-resend-form .btn,.auth-resend-form a{width:100%!important}}

/* 2026-05-10 final mobile responsiveness pass */
*, *::before, *::after { box-sizing: border-box; }
html, body { max-width: 100%; overflow-x: clip; }
img, svg, video, canvas { max-width: 100%; height: auto; }
input, select, textarea, button { max-width: 100%; }

.search-preview-shell { background: #fff; padding: clamp(52px, 7vw, 80px) 0; }
.home-final-cta-wrap { padding: clamp(28px, 6vw, 48px) clamp(16px, 4vw, 24px); background: var(--bg-light); }

.cards-grid,
.cards-grid-3,
.cards-grid-3x2,
.projects-public-grid,
.repository-grid,
.audience-grid,
.docs-grid,
.resource-grid,
.testimonial-grid,
.pricing-grid {
  min-width: 0 !important;
}

.latest-records-section .section-heading { padding-inline: 16px; }
.projects-public-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(14px, 2.5vw, 22px) !important;
  width: min(1200px, calc(100% - 48px)) !important;
}
.project-public-card,
.feature-card,
.docs-card,
.pricing-card,
.audience-card,
.resource-card,
.testimonial-card {
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}
.project-public-card h3,
.project-public-card p,
.project-public-card small {
  overflow-wrap: anywhere !important;
}
.project-public-card .btn { align-self: flex-start; }

.admin-topbar { min-width: 0 !important; }
.admin-topbar-title { min-width: 0 !important; }
body.admin-mobile-command-open { overflow-x: hidden; }
body.admin-mobile-command-open::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 998;
  background: rgba(15, 23, 42, .34);
  backdrop-filter: blur(2px);
}
body.admin-mobile-command-open .admin-search {
  display: flex !important;
  position: fixed !important;
  top: calc(env(safe-area-inset-top, 0px) + 72px) !important;
  left: 14px !important;
  right: 14px !important;
  z-index: 999 !important;
  width: auto !important;
  max-width: none !important;
  height: auto !important;
  min-height: 56px !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(22, 163, 74, .25) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 24px 70px rgba(15, 31, 22, .22) !important;
}
body.admin-mobile-command-open .admin-search input {
  display: block !important;
  width: 100% !important;
  min-height: 40px !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  font-size: 16px !important;
}
body.admin-mobile-command-open .admin-search .dash-nav-search-kbd { display: none !important; }
body.admin-mobile-command-open .suggest-box {
  position: fixed !important;
  left: 14px !important;
  right: 14px !important;
  top: calc(env(safe-area-inset-top, 0px) + 136px) !important;
  width: auto !important;
  max-height: min(420px, calc(100vh - 160px)) !important;
  overflow: auto !important;
  z-index: 1000 !important;
  border-radius: var(--inrep-radius, 10px) !important;
}

.admin-table-wrap,
.table-responsive {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior-inline: contain !important;
}
.admin-table-wrap::before,
.table-responsive::before {
  content: attr(data-scroll-hint);
  display: none;
  padding: 10px 12px;
  color: #64756a;
  font-size: 12px;
  font-weight: 800;
  background: #f8faf9;
  border-bottom: 1px solid #e5eee8;
}
.admin-table-wrap table,
.table-responsive table,
.admin-main table {
  max-width: 100% !important;
}

@media (max-width: 1180px) {
  .cards-grid:not(.cards-grid-3):not(.cards-grid-3x2),
  .resource-grid,
  .pricing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .pricing-tier-grid,
  .admin-plan-grid,
  .operations-storage-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .docs-article-section,
  .project-detail-rebuilt,
  .contact-grid,
  .solution-row { grid-template-columns: 1fr !important; }
  .docs-related-card { position: static !important; }
}

@media (max-width: 960px) {
  .cards-section, .workflow-section, .audience-section,
  .search-preview-section, .testimonial-section, .pricing-section, .faq-section {
    padding-top: clamp(48px, 8vw, 66px) !important;
    padding-bottom: clamp(48px, 8vw, 66px) !important;
  }
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .projects-public-grid,
  .repository-grid,
  .audience-grid,
  .docs-grid,
  .testimonial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: min(100% - 32px, 720px) !important;
  }
  .feature-showcase-grid,
  .search-preview-section,
  .search-preview-section.container,
  .workflow-grid,
  .filter-main,
  .mkt-page .admin-filter-bar {
    grid-template-columns: 1fr !important;
    width: min(100% - 32px, 720px) !important;
  }
  .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .stat-item:nth-child(2n) { border-right: 0 !important; }
  .repository-results-head,
  .help-panel,
  .admin-page-header,
  .security-setting-panel {
    flex-direction: column !important;
    align-items: stretch !important;
  }
}

@media (max-width: 760px) {
  .mkt-container,
  .status-board,
  .repository-filter-card,
  .repository-results-head,
  .project-detail-rebuilt,
  .contact-grid,
  .solution-list,
  .resource-grid,
  .docs-grid,
  .help-panel,
  .timeline-rebuilt,
  .pricing-tier-grid,
  .pricing-compare-table,
  .admin-plan-grid,
  .docs-article-section {
    width: calc(100% - 28px) !important;
  }
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .projects-public-grid,
  .repository-grid,
  .audience-grid,
  .docs-grid,
  .resource-grid,
  .testimonial-grid,
  .pricing-grid,
  .pricing-tier-grid,
  .admin-plan-grid,
  .operations-storage-grid {
    grid-template-columns: 1fr !important;
    width: calc(100% - 28px) !important;
    gap: 14px !important;
  }
  .project-public-card,
  .feature-card,
  .docs-card,
  .pricing-card,
  .audience-card,
  .resource-card,
  .testimonial-card,
  .search-preview-card,
  .project-detail-main,
  .project-detail-side,
  .contact-card,
  .solution-row {
    border-radius: var(--inrep-radius, 10px) !important;
    padding: 18px !important;
  }
  .hero-search,
  .docs-search,
  .filter-actions,
  .hero-ctas,
  .docs-article-actions,
  .admin-actions,
  .admin-form-actions,
  .table-actions,
  .inline-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }
  .hero-search input,
  .hero-search button,
  .docs-search input,
  .docs-search button,
  .filter-actions .btn,
  .hero-ctas a,
  .docs-article-actions a,
  .admin-actions .btn,
  .table-actions .btn,
  .inline-actions .btn {
    width: 100% !important;
    justify-content: center !important;
  }
  .workflow-tabs { overflow-x: auto !important; flex-direction: row !important; padding-bottom: 6px !important; }
  .workflow-tab { min-width: 180px !important; }
  .metadata-grid,
  .admin-form-grid-2,
  .admin-form-grid-3,
  .payment-settings-form,
  .webhook-url-grid,
  .subscription-choice-form {
    grid-template-columns: 1fr !important;
  }
  .pricing-compare-table,
  .admin-table-wrap,
  .table-responsive {
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .admin-table-wrap::before,
  .table-responsive::before { display: block; }
  .admin-table-wrap:not([data-scroll-hint])::before,
  .table-responsive:not([data-scroll-hint])::before { content: 'Swipe left to see more columns'; }
  .table-bulk-bar { display: grid !important; grid-template-columns: 1fr !important; }
  .table-bulk-bar .btn,
  .table-bulk-bar input,
  .table-bulk-bar select { width: 100% !important; max-width: 100% !important; justify-content: center !important; }
  .admin-pagination { justify-content: flex-start !important; }
  .admin-pagination span { width: 100% !important; padding-left: 0 !important; }
}

@media (max-width: 640px) {
  .admin-page { padding-inline: 0 !important; }
  .admin-main { padding: 16px 12px 96px !important; }
  .admin-panel { border-radius: var(--inrep-radius, 10px) !important; }
  .admin-panel > h2, .admin-panel-body { padding: 16px !important; }
  .admin-topbar-title { max-width: 38vw !important; font-size: 13px !important; }
  .admin-topbar .mkt-nav-logo { min-width: 34px !important; }
  .site-chatbot {
    right: max(12px, env(safe-area-inset-right)) !important;
    bottom: calc(74px + env(safe-area-inset-bottom, 0px)) !important;
  }
  .site-chatbot-panel {
    width: calc(100vw - 24px) !important;
    right: 0 !important;
    bottom: 64px !important;
    max-height: min(560px, calc(100vh - 132px)) !important;
  }
  .latest-records-section .projects-public-grid { grid-template-columns: 1fr !important; }
  .project-public-card h3 { font-size: 15px !important; line-height: 1.35 !important; }

  .admin-table-wrap[data-mobile-card="1"],
  .table-responsive[data-mobile-card="1"] { overflow: visible !important; }
  .admin-table-wrap[data-mobile-card="1"]::before,
  .table-responsive[data-mobile-card="1"]::before { display: none !important; }
  .admin-table-wrap[data-mobile-card="1"] table,
  .table-responsive[data-mobile-card="1"] table,
  .admin-table-wrap[data-mobile-card="1"] thead,
  .table-responsive[data-mobile-card="1"] thead,
  .admin-table-wrap[data-mobile-card="1"] tbody,
  .table-responsive[data-mobile-card="1"] tbody,
  .admin-table-wrap[data-mobile-card="1"] tr,
  .table-responsive[data-mobile-card="1"] tr,
  .admin-table-wrap[data-mobile-card="1"] th,
  .table-responsive[data-mobile-card="1"] th,
  .admin-table-wrap[data-mobile-card="1"] td,
  .table-responsive[data-mobile-card="1"] td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .admin-table-wrap[data-mobile-card="1"] table,
  .table-responsive[data-mobile-card="1"] table { border: 0 !important; background: transparent !important; }
  .admin-table-wrap[data-mobile-card="1"] thead,
  .table-responsive[data-mobile-card="1"] thead { position: absolute !important; width: 1px !important; height: 1px !important; overflow: hidden !important; clip: rect(0 0 0 0) !important; }
  .admin-table-wrap[data-mobile-card="1"] tbody,
  .table-responsive[data-mobile-card="1"] tbody { display: grid !important; gap: 12px !important; }
  .admin-table-wrap[data-mobile-card="1"] tr,
  .table-responsive[data-mobile-card="1"] tr {
    background: #fff !important;
    border: 1px solid #dfe9e3 !important;
    border-radius: var(--inrep-radius, 10px) !important;
    box-shadow: 0 10px 28px rgba(15,31,22,.06) !important;
    padding: 8px !important;
  }
  .admin-table-wrap[data-mobile-card="1"] td,
  .table-responsive[data-mobile-card="1"] td {
    display: grid !important;
    grid-template-columns: minmax(92px, 34%) minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: start !important;
    padding: 10px 8px !important;
    border-bottom: 1px solid #eef4f0 !important;
    text-align: left !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }
  .admin-table-wrap[data-mobile-card="1"] td:last-child,
  .table-responsive[data-mobile-card="1"] td:last-child { border-bottom: 0 !important; }
  .admin-table-wrap[data-mobile-card="1"] td::before,
  .table-responsive[data-mobile-card="1"] td::before {
    content: attr(data-label);
    color: #64756a;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .05em;
  }
  .admin-table-wrap[data-mobile-card="1"] td[data-label=""],
  .table-responsive[data-mobile-card="1"] td[data-label=""] { grid-template-columns: 1fr !important; }
  .admin-table-wrap[data-mobile-card="1"] td[data-label=""]::before,
  .table-responsive[data-mobile-card="1"] td[data-label=""]::before { display: none !important; }
  .admin-table-wrap[data-mobile-card="1"] .table-actions,
  .admin-table-wrap[data-mobile-card="1"] .inline-actions,
  .table-responsive[data-mobile-card="1"] .table-actions,
  .table-responsive[data-mobile-card="1"] .inline-actions {
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }
}

@media (max-width: 420px) {
  .mkt-hero-grid,
  .mkt-container,
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .projects-public-grid,
  .repository-grid,
  .audience-grid,
  .docs-grid,
  .resource-grid,
  .testimonial-grid,
  .pricing-grid,
  .repository-filter-card,
  .repository-results-head,
  .search-preview-section,
  .search-preview-section.container {
    width: calc(100% - 22px) !important;
  }
  .section-heading { margin-bottom: 26px !important; padding-inline: 11px !important; }
  .stat-number, .stat-value { font-size: 32px !important; }
  .stats-grid { grid-template-columns: 1fr !important; }
  .stat-item { border-right: 0 !important; border-bottom: 1px solid var(--border-light) !important; }
  .stat-item:last-child { border-bottom: 0 !important; }
  .admin-topbar-title { max-width: 32vw !important; }
  .admin-table-wrap[data-mobile-card="1"] td,
  .table-responsive[data-mobile-card="1"] td { grid-template-columns: 1fr !important; }
}


/* 2026-05-10 mobile cross-check fixes: public nav search + final mobile polish */
@media (max-width: 1024px) {
  .public-body .mkt-nav {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 10px !important;
    padding-inline: clamp(12px, 4vw, 20px) !important;
  }
  .public-body .mkt-nav-logo {
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .public-body .mkt-nav-logo span:not(.inrep-mark) {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }
  .public-body .mkt-nav-items,
  .public-body .mkt-nav-search {
    display: none !important;
  }
  .public-body .mkt-nav-actions {
    justify-self: end !important;
    min-width: 0 !important;
    margin-left: auto !important;
  }
  .public-body .mkt-nav-toggle {
    display: inline-grid !important;
    justify-self: end !important;
    flex: 0 0 40px !important;
    width: 40px !important;
    height: 40px !important;
  }
}

@media (max-width: 700px) {
  .public-body .mkt-nav-actions {
    display: none !important;
  }
  .public-body .mkt-nav {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }
}

.mkt-mobile-drawer {
  width: min(390px, 92vw) !important;
  max-width: 100vw !important;
  padding: max(16px, env(safe-area-inset-top, 0px)) 16px max(16px, env(safe-area-inset-bottom, 0px)) !important;
}

.mkt-mobile-search {
  width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 20px minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 0 14px !important;
  padding: 10px !important;
  border: 1px solid rgba(22, 163, 74, .22) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(180deg, #fff, #f8faf9) !important;
  box-shadow: 0 10px 28px rgba(15, 31, 22, .07) !important;
}

.mkt-mobile-search svg {
  width: 18px !important;
  height: 18px !important;
  color: var(--primary) !important;
  flex: 0 0 auto !important;
}

.mkt-mobile-search input {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 42px !important;
  padding: 0 !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--text-dark) !important;
  font-size: 16px !important;
  line-height: 1.2 !important;
}

.mkt-mobile-search button {
  min-height: 40px !important;
  padding: 0 13px !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

.mkt-mobile-links {
  min-height: 0 !important;
  padding-right: 2px !important;
}

.mkt-mobile-footer {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

@media (max-width: 380px) {
  .mkt-mobile-drawer {
    width: 100vw !important;
    padding-inline: 14px !important;
  }
  .mkt-mobile-search {
    grid-template-columns: 20px minmax(0, 1fr) !important;
  }
  .mkt-mobile-search button {
    grid-column: 1 / -1 !important;
    width: 100% !important;
  }
  .mkt-mobile-footer {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .latest-records-section .projects-public-grid,
  .latest-records-section .project-public-card {
    width: 100% !important;
    max-width: 100% !important;
  }
  .latest-records-section .projects-public-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 1023px) {
  .admin-topbar {
    display: grid !important;
    grid-template-columns: auto auto minmax(0, 1fr) auto auto !important;
    align-items: center !important;
  }
  .admin-topbar-actions {
    justify-self: end !important;
    margin-left: 0 !important;
  }
}

@media (max-width: 430px) {
  .admin-topbar {
    grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  }
  .admin-topbar-actions > a.admin-icon-btn {
    display: none !important;
  }
}

/* Growth suite additions */
.hero-search{display:flex;gap:10px;align-items:center;margin:22px 0;max-width:720px}.hero-search input{flex:1;min-height:52px;border:1px solid rgba(15,23,42,.14);border-radius:var(--inrep-radius, 10px) !important;padding:0 18px;font:inherit}.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.stat-grid div,.admin-kpi-card{background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 16px 40px rgba(15,23,42,.06);border-radius:var(--inrep-radius, 10px) !important;padding:18px}.stat-grid strong,.admin-kpi-card strong{display:block;font-size:clamp(1.7rem,4vw,2.8rem);line-height:1;color:#0f172a}.stat-grid span,.admin-kpi-card span{color:#64748b;font-weight:700}.public-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.public-card{display:flex;flex-direction:column;gap:10px;padding:20px;border-radius:var(--inrep-radius, 10px) !important;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 20px 50px rgba(15,23,42,.07);text-decoration:none;color:#0f172a}.public-card strong{font-size:1rem}.public-card span,.public-card small{color:#64748b}.tag-cloud{display:flex;flex-wrap:wrap;gap:10px}.tag-cloud a,.tag-cloud span{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:var(--inrep-radius, 10px) !important;background:#eefdf3;border:1px solid rgba(22,163,74,.18);color:#166534;text-decoration:none;font-weight:700}.tag-cloud small{opacity:.75}.ai-answer-box{white-space:pre-wrap;background:#0f172a;color:#e5e7eb;border-radius:var(--inrep-radius, 10px) !important;padding:18px;overflow:auto}.score-pill{display:inline-flex;align-items:center;justify-content:center;min-width:82px;height:82px;border-radius:var(--inrep-radius, 10px) !important;background:#ecfdf5;color:#047857;font-size:1.35rem;border:1px solid rgba(4,120,87,.2)}.feature-list{padding-left:18px;color:#475569}.feature-list li{margin:8px 0}.advanced-search-form .form-grid-compact{grid-template-columns:2fr 1fr 1fr 1fr}.public-portal-hero .mkt-hero-panel{align-self:stretch}@media (max-width: 980px){.public-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.advanced-search-form .form-grid-compact{grid-template-columns:1fr 1fr}.hero-search{flex-direction:column;align-items:stretch}.hero-search .btn{width:100%}}@media (max-width: 640px){.public-card-grid,.stat-grid{grid-template-columns:1fr}.advanced-search-form .form-grid-compact{grid-template-columns:1fr}.score-pill{width:70px;height:70px;min-width:70px}.public-card{padding:16px;border-radius:var(--inrep-radius, 10px) !important}}

/* Installer layout polish - 2026-05-10 */
:root{--install-green:#0f6b3a;--install-green-2:#14b86a;--install-ink:#071510;--install-muted:#5c6f66;--install-line:#dfeae4;--install-soft:#f4fbf7;--install-shadow:0 24px 70px rgba(3,44,24,.14)}
body.install-body{margin:0;min-height:100vh;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--install-ink);background:radial-gradient(circle at 10% 10%,#dff7e8 0,#fff 36%,#f5fbf8 100%);display:flex;align-items:center;justify-content:center;padding:28px}.install-shell{width:min(1180px,100%);display:grid;grid-template-columns:minmax(300px,.9fr) minmax(420px,1.1fr);gap:26px;align-items:stretch}.install-showcase,.install-panel{border:1px solid var(--install-line);border-radius:var(--inrep-radius, 10px) !important;background:rgba(255,255,255,.88);box-shadow:var(--install-shadow);backdrop-filter:blur(18px)}.install-showcase{padding:34px;display:flex;flex-direction:column;justify-content:space-between;min-height:640px;overflow:hidden;position:relative}.install-showcase:before{content:"";position:absolute;inset:auto -90px -120px auto;width:300px;height:300px;border-radius:var(--inrep-radius, 10px) !important;background:linear-gradient(135deg,rgba(20,184,106,.22),rgba(15,107,58,.08))}.install-panel{padding:34px}.install-eyebrow{display:inline-flex;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--install-green);margin-bottom:8px}.install-showcase h2,.install-panel h1{margin:0 0 14px;font-size:clamp(30px,4vw,52px);line-height:1.02;letter-spacing:-.045em}.install-panel h1{font-size:clamp(26px,3vw,38px)}.install-showcase p,.install-copy,.install-note{color:var(--install-muted);line-height:1.65;margin:0}.install-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;position:relative}.install-mini{padding:16px;border:1px solid var(--install-line);border-radius:var(--inrep-radius, 10px) !important;background:#fff}.install-mini b{display:block;font-size:16px}.install-mini span{display:block;color:var(--install-muted);font-size:13px;margin-top:4px}.install-progress{height:7px;border-radius:var(--inrep-radius, 10px) !important;background:#e6f3ec;margin-bottom:24px;overflow:hidden}.install-progress span{display:block;width:100%;height:100%;background:linear-gradient(90deg,var(--install-green),var(--install-green-2))}.install-checks{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 24px}.install-pill{border-radius:var(--inrep-radius, 10px) !important;padding:8px 11px;font-size:12px;font-weight:800;border:1px solid var(--install-line);background:#fff}.install-pill.ok{color:#096334;background:#effbf4;border-color:#cfeedd}.install-pill.bad{color:#9a3412;background:#fff7ed;border-color:#fed7aa}.install-alert{padding:14px 16px;border-radius:var(--inrep-radius, 10px) !important;margin:16px 0;font-weight:800}.install-alert.error{background:#fff1f2;color:#9f1239;border:1px solid #fecdd3}.install-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.install-group-title{grid-column:1/-1;font-weight:900;color:#173c2b;margin-top:4px}.install-form input{width:100%;min-height:50px;border:1px solid var(--install-line);border-radius:var(--inrep-radius, 10px) !important;background:#fff;padding:0 14px;font:inherit;color:var(--install-ink);outline:none}.install-form input:focus{border-color:var(--install-green-2);box-shadow:0 0 0 4px rgba(20,184,106,.12)}.install-note{grid-column:1/-1;font-size:13px;padding:10px 12px;border-radius:var(--inrep-radius, 10px) !important;background:var(--install-soft);border:1px solid #d8efe3}.install-form .btn,.install-form button{appearance:none;border:0;border-radius:var(--inrep-radius, 10px) !important;min-height:52px;padding:0 22px;font-weight:900;cursor:pointer}.install-form .btn.primary,.install-form button.primary{background:linear-gradient(135deg,var(--install-green),var(--install-green-2));color:#fff;box-shadow:0 12px 26px rgba(20,184,106,.25)}@media(max-width:900px){body.install-body{display:block;padding:18px}.install-shell{grid-template-columns:1fr}.install-showcase{min-height:auto;gap:32px}.install-panel{padding:24px}.install-showcase{padding:24px}}@media(max-width:560px){body.install-body{padding:0;background:#fff}.install-shell{gap:0}.install-showcase,.install-panel{border-radius:var(--inrep-radius, 10px) !important;border-left:0;border-right:0;box-shadow:none}.install-form{grid-template-columns:1fr}.install-mini-grid{grid-template-columns:1fr}.install-showcase h2{font-size:32px}.install-panel h1{font-size:28px}.install-checks{display:grid;grid-template-columns:1fr 1fr}.install-pill{text-align:center}.install-form .btn,.install-form button{width:100%}}

/* Operational growth feature pages */
.timeline-list{position:relative;display:grid;gap:14px}.timeline-item{position:relative;display:grid;grid-template-columns:26px 1fr;gap:12px;padding:14px;border:1px solid var(--border,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:#fff}.timeline-dot{width:12px;height:12px;border-radius:var(--inrep-radius, 10px) !important;background:#1f883d;margin-top:5px;box-shadow:0 0 0 5px rgba(31,136,61,.12)}.log-viewer{max-height:420px;overflow:auto;background:#0f172a;color:#dbeafe;border-radius:var(--inrep-radius, 10px) !important;padding:16px;font-size:12px;line-height:1.55;white-space:pre-wrap}.tag-cloud span{display:inline-flex;align-items:center;margin:4px;padding:7px 10px;border-radius:var(--inrep-radius, 10px) !important;background:#f1f5f9;border:1px solid #e2e8f0;font-size:12px}.admin-grid-5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}@media(max-width:1100px){.admin-grid-5{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.admin-grid-5{grid-template-columns:1fr}.timeline-item{grid-template-columns:18px 1fr;padding:12px}.log-viewer{font-size:11px}}

/* Student workspace and public contact refinements */
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.tag-row span{display:inline-flex;align-items:center;border:1px solid rgba(15,23,42,.12);background:#f8fafc;border-radius:var(--inrep-radius, 10px) !important;padding:6px 10px;font-size:12px;font-weight:700;color:#334155}.clean-list.numbered{list-style:decimal;padding-left:20px}.student-tool-page .admin-card strong{font-size:32px;line-height:1}.mkt-footer-emails{display:grid;gap:6px;margin-top:12px}.mkt-footer-emails a{color:rgba(255,255,255,.72);font-size:13px;text-decoration:none}.mkt-footer-emails a:hover{color:#fff;text-decoration:underline}

/* 2026-05-11: table density, signup selector, impersonation polish */
.mkt-nav-actions{gap:10px!important;align-items:center!important;white-space:nowrap!important}.mkt-nav-signin,.mkt-nav-signup{min-width:max-content!important}
.signup-choice-form .form-section-title{margin-top:0}.signup-choice-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.signup-choice-card{display:grid;gap:8px;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;padding:18px;background:#fff;cursor:pointer;min-height:132px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.signup-choice-card:hover{border-color:rgba(29,185,84,.55);box-shadow:0 12px 32px rgba(10,31,21,.08);transform:translateY(-1px)}.signup-choice-card input{width:auto;min-height:auto;margin:0;accent-color:var(--primary)}.signup-choice-card strong{font-family:var(--font-display);font-size:17px;color:var(--heading)}.signup-choice-card span,.signup-choice-domain-note,.school-email-domain-note{color:var(--muted);font-size:13px;line-height:1.5}.selected-plan-inline{display:inline-flex;gap:10px;align-items:center;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--inrep-radius, 10px) !important;background:#fff;margin-top:12px}.selected-plan-inline span{color:var(--muted);font-weight:700}
.admin-table-wrap{width:100%!important;max-width:100%!important;overflow-x:auto!important;overflow-y:visible!important;-webkit-overflow-scrolling:touch!important;border:1px solid var(--border-light)!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;box-shadow:0 10px 28px rgba(10,31,21,.05)!important}.admin-panel>.admin-table-wrap{margin-top:14px!important}.admin-table-wrap table,.admin-panel table,.admin-main table,.admin-table{width:100%!important;min-width:920px!important;border-collapse:separate!important;border-spacing:0!important;background:#fff!important;table-layout:auto!important}.admin-table th,.admin-table td,.admin-table-wrap th,.admin-table-wrap td,.admin-main table th,.admin-main table td{padding:16px 18px!important;line-height:1.45!important;vertical-align:middle!important;white-space:normal!important;word-break:normal!important;overflow-wrap:normal!important}.admin-table th,.admin-table-wrap thead th,.admin-main table thead th{position:sticky!important;top:0!important;z-index:2!important;background:#f3f8f3!important;color:#5f7164!important;font-size:11px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.08em!important;white-space:nowrap!important}.admin-table td:first-child,.admin-table th:first-child,.admin-table-wrap td:first-child,.admin-table-wrap th:first-child{width:auto!important;min-width:130px!important;text-align:left!important}.admin-table td:first-child:has(input[type="checkbox"]),.admin-table th:first-child:has(input[type="checkbox"]){width:48px!important;min-width:48px!important;text-align:center!important}.admin-table td:last-child,.admin-table th:last-child{min-width:110px!important}.admin-table .cell-mono,.admin-table code,.admin-table-wrap code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace!important;white-space:normal!important;overflow-wrap:anywhere!important;word-break:normal!important}.admin-table .status-badge{white-space:nowrap!important}.admin-table .table-actions,.admin-table .inline-actions,.admin-table .inline-form{display:flex!important;flex-wrap:wrap!important;gap:8px!important;align-items:center!important;margin:0!important}.admin-table input:not([type="checkbox"]),.admin-table select{min-width:180px!important;max-width:260px!important;min-height:38px!important;padding:8px 10px!important}.admin-table .btn,.admin-table button{white-space:nowrap!important}.institution-detail-table-wrap table,.institution-detail-table{min-width:0!important;table-layout:fixed!important}.institution-detail-table th:first-child,.institution-detail-table td:first-child{width:220px!important;min-width:220px!important;max-width:220px!important;text-align:left!important;white-space:normal!important}.institution-detail-table th:nth-child(2),.institution-detail-table td:nth-child(2){width:auto!important}.institution-detail-table td{vertical-align:top!important}.institution-detail-table td strong{display:block;line-height:1.25;word-break:normal!important}.institution-detail-table td small{display:block;color:var(--muted);font-weight:600;margin-top:3px}.institution-detail-table code{display:inline-block!important;max-width:100%!important;padding:7px 10px!important;border-radius:var(--inrep-radius, 10px) !important;background:#f7fbf7!important;color:#047021!important;line-height:1.5!important}.invoice-admin-table th:first-child,.invoice-admin-table td:first-child{min-width:190px!important}.invoice-admin-table th:nth-child(4),.invoice-admin-table td:nth-child(4){min-width:360px!important}.institution-users-table th:nth-child(2),.institution-users-table td:nth-child(2){min-width:240px!important}.impersonation-table th:first-child,.impersonation-table td:first-child{min-width:280px!important}.impersonation-table th:nth-child(3),.impersonation-table td:nth-child(3){min-width:220px!important}.impersonation-form input{min-width:220px!important}.admin-panel-header{gap:16px!important;align-items:flex-start!important}.admin-panel-header>div{min-width:0}.admin-panel-header .mini-muted{display:block;margin-top:4px;color:var(--muted)}
@media(max-width:900px){.signup-choice-cards{grid-template-columns:1fr}.admin-table-wrap table,.admin-panel table,.admin-main table,.admin-table{min-width:780px!important}.institution-detail-table-wrap table,.institution-detail-table{min-width:620px!important}.invoice-admin-table th:nth-child(4),.invoice-admin-table td:nth-child(4){min-width:280px!important}}
@media(max-width:640px){.admin-table th,.admin-table td,.admin-table-wrap th,.admin-table-wrap td{padding:13px 14px!important}.institution-detail-table th:first-child,.institution-detail-table td:first-child{width:170px!important;min-width:170px!important;max-width:170px!important}.signup-choice-page .auth-card{padding:20px!important}.mkt-mobile-footer{grid-template-columns:1fr!important}.mkt-mobile-footer .btn{width:100%!important}}

/* 2026-05-10: final table, signup and raw-field polish */
.signup-choice-card input[type="radio"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  flex: 0 0 18px !important;
  margin: 3px 10px 0 0 !important;
  accent-color: var(--primary, #1f883d) !important;
}
.signup-choice-card {
  display: grid !important;
  grid-template-columns: 28px minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 4px 10px !important;
  padding: 18px !important;
}
.signup-choice-card strong,
.signup-choice-card span { grid-column: 2 !important; }
.signup-choice-card span { line-height: 1.45 !important; }
.signup-study-level-wrap[hidden],
[data-study-level-wrap][hidden] { display: none !important; }

.institution-detail-table-wrap,
.invoice-admin-table-wrap { border-radius: var(--inrep-radius, 10px) !important; }
.institution-detail-table {
  min-width: 0 !important;
  table-layout: fixed !important;
}
.institution-detail-table th:first-child,
.institution-detail-table td:first-child {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 220px !important;
  text-align: left !important;
  vertical-align: top !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
}
.institution-detail-table td:first-child strong,
.institution-detail-table td:first-child small {
  display: block !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  line-height: 1.35 !important;
}
.institution-detail-table td:nth-child(2) {
  min-width: 0 !important;
  white-space: normal !important;
}
.institution-detail-table code,
.invoice-admin-table .cell-mono,
.institution-users-table .cell-mono {
  max-width: 100% !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-height: 1.45 !important;
}
.invoice-admin-table {
  min-width: 980px !important;
  table-layout: fixed !important;
}
.invoice-admin-table th:nth-child(1),
.invoice-admin-table td:nth-child(1) { width: 190px !important; }
.invoice-admin-table th:nth-child(2),
.invoice-admin-table td:nth-child(2) { width: 140px !important; white-space: nowrap !important; }
.invoice-admin-table th:nth-child(3),
.invoice-admin-table td:nth-child(3) { width: 120px !important; }
.invoice-admin-table th:nth-child(4),
.invoice-admin-table td:nth-child(4) { width: auto !important; }
.invoice-admin-table th:nth-child(5),
.invoice-admin-table td:nth-child(5) { width: 180px !important; white-space: nowrap !important; }
.admin-table-wrap .admin-table td,
.admin-table-wrap .admin-table th {
  min-width: 0 !important;
}
@media (max-width: 760px) {
  .institution-detail-table,
  .invoice-admin-table { min-width: 760px !important; }
  .institution-detail-table th:first-child,
  .institution-detail-table td:first-child {
    width: 180px !important;
    min-width: 180px !important;
    max-width: 180px !important;
  }
}

/* 20260511: public cleanup, centered headers, rich institution/preprint pages */
.public-body .mkt-nav-actions{display:flex!important;align-items:center!important;justify-content:center!important;gap:10px!important}
.public-body .hero-ctas,.public-body .mkt-hero-ctas,.preprint-hero-actions{display:flex!important;align-items:center!important;justify-content:center!important;gap:12px!important;flex-wrap:wrap!important;margin-left:auto!important;margin-right:auto!important;width:100%!important}
.public-body .page-hero{text-align:center!important;overflow:hidden!important}
.public-body .page-hero .btn,.public-body .page-hero a.btn{position:static!important;float:none!important}
.preprint-hero{padding:clamp(72px,8vw,128px) 24px clamp(54px,7vw,96px)!important;background:linear-gradient(180deg,#f7fff9 0%,#fff 100%)!important}
.preprint-hero .page-hero-h1{max-width:920px!important;margin-left:auto!important;margin-right:auto!important}
.preprint-hero .page-hero-sub{max-width:760px!important;margin-left:auto!important;margin-right:auto!important}
.preprint-workflow-section,.institution-rich-overview,.institution-guidance-section{padding:clamp(56px,6vw,88px) 24px!important}
.preprint-process-grid,.institution-guide-grid{width:min(1180px,100%)!important;margin:0 auto!important;display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:18px!important}
.preprint-process-grid article,.institution-guide-grid article,.institution-rich-card{background:#fff!important;border:1px solid var(--border-light,#dfe7df)!important;border-radius:var(--inrep-radius, 10px) !important;padding:24px!important;box-shadow:0 16px 44px rgba(10,31,21,.07)!important;text-align:left!important}
.preprint-process-grid strong{display:inline-grid!important;place-items:center!important;width:34px!important;height:34px!important;border-radius:var(--inrep-radius, 10px) !important;background:#1db954!important;color:#fff!important;margin-bottom:14px!important}
.preprint-grid{width:min(1180px,calc(100% - 48px))!important;margin:auto!important;display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:22px!important}
.preprint-card{background:#fff!important;border:1px solid var(--border-light,#dfe7df)!important;border-radius:var(--inrep-radius, 10px) !important;padding:26px!important;box-shadow:0 18px 50px rgba(10,31,21,.08)!important;display:flex!important;flex-direction:column!important;gap:16px!important;text-align:left!important;min-width:0!important}
.preprint-card h2{font-size:clamp(20px,2vw,26px)!important;line-height:1.2!important;margin:0!important;overflow-wrap:anywhere!important}
.preprint-card p{color:var(--muted,#617266)!important;line-height:1.65!important;margin:0!important}
.preprint-card-meta{display:flex!important;justify-content:space-between!important;gap:10px!important;flex-wrap:wrap!important;color:#42604d!important;font-size:12px!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:.08em!important}
.preprint-detail-list{display:grid!important;gap:8px!important;margin:0!important}.preprint-detail-list div{display:flex!important;justify-content:space-between!important;gap:16px!important;border-top:1px solid #edf2ed!important;padding-top:8px!important}.preprint-detail-list dt{color:var(--muted,#617266)!important}.preprint-detail-list dd{margin:0!important;font-weight:800!important;text-align:right!important}
.institution-rich-grid{width:min(1180px,100%)!important;margin:0 auto!important;display:grid!important;grid-template-columns:2fr 1fr 1fr!important;gap:18px!important}.institution-rich-card-large{grid-row:span 1!important}.institution-rich-card h2,.institution-rich-card h3{margin:8px 0 10px!important}.institution-rich-card p{line-height:1.7!important;color:var(--muted,#617266)!important}.institution-contact-strip{display:flex!important;gap:10px!important;flex-wrap:wrap!important;margin-top:18px!important}.institution-contact-strip a,.institution-contact-strip span{display:inline-flex!important;border:1px solid var(--border-light,#dfe7df)!important;border-radius:var(--inrep-radius, 10px) !important;padding:8px 12px!important;font-weight:800!important;background:#f7fbf7!important}
.student-dashboard-page .admin-page-title{min-width:0!important}.student-dashboard-page .admin-actions{justify-content:flex-end!important;flex-wrap:wrap!important}
@media (max-width:980px){.preprint-process-grid,.institution-guide-grid,.preprint-grid,.institution-rich-grid{grid-template-columns:1fr 1fr!important}.institution-rich-card-large{grid-column:1/-1!important}}
@media (max-width:640px){.preprint-process-grid,.institution-guide-grid,.preprint-grid,.institution-rich-grid{grid-template-columns:1fr!important;width:calc(100% - 32px)!important}.public-body .hero-ctas .btn,.public-body .hero-ctas a{width:100%!important;justify-content:center!important}.preprint-detail-list div{display:block!important}.preprint-detail-list dd{text-align:left!important;margin-top:3px!important}}


/* 20260511 final: visible secondary buttons, simple public nav, roles/signup polish */
.public-body .mkt-nav{
  grid-template-columns:auto 1fr auto!important;
  justify-content:center!important;
}
.public-body .mkt-nav .mkt-nav-actions{
  justify-self:end!important;
}
.public-body .mkt-nav-actions .mkt-nav-signin,
.public-body .mkt-nav-actions .mkt-nav-signup,
.public-body .mkt-mobile-footer .btn{
  min-width:104px!important;
  justify-content:center!important;
}
.public-body .btn.secondary,
.public-body .btn.btn-secondary,
.public-body .btn-outline-white,
.public-body .btn-hero-secondary,
.public-body .hero-actions a:not(.btn-hero-primary),
.public-body .hero-ctas a:not(.primary):not(.btn-hero-primary){
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:48px!important;
  padding:13px 22px!important;
  border-radius:var(--inrep-radius, 10px) !important;
  border:1px solid rgba(31,136,61,.34)!important;
  background:#fff!important;
  color:#0f7a34!important;
  font-weight:800!important;
  text-decoration:none!important;
  box-shadow:0 12px 30px rgba(9,77,37,.08)!important;
}
.public-body .btn.secondary:hover,
.public-body .btn.btn-secondary:hover,
.public-body .btn-outline-white:hover,
.public-body .btn-hero-secondary:hover,
.public-body .hero-actions a:not(.btn-hero-primary):hover,
.public-body .hero-ctas a:not(.primary):not(.btn-hero-primary):hover{
  background:#effff4!important;
  border-color:rgba(31,136,61,.64)!important;
  color:#065f26!important;
  transform:translateY(-1px)!important;
}
.preprint-hero-polished{
  text-align:center!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:560px!important;
}
.preprint-hero-polished .hero-ctas{margin-top:26px!important;}
.preprint-workflow-section .section-heading,
.preprint-list-section .section-heading{text-align:center!important;max-width:760px!important;margin:0 auto 28px!important;}
.signup-choice-v2{padding:clamp(28px,5vw,64px) 24px!important;background:#f5faf6!important;min-height:100vh!important;}
.signup-choice-v2 .auth-choice-hero{max-width:1100px!important;margin:0 auto 24px!important;background:#0b3d2a!important;color:#fff!important;border-radius:var(--inrep-radius, 10px) !important;padding:clamp(30px,5vw,56px)!important;box-shadow:0 24px 70px rgba(10,31,21,.14)!important;}
.signup-choice-v2 .auth-choice-hero h1{font-size:clamp(36px,5vw,68px)!important;line-height:1.02!important;margin:14px 0!important;}
.signup-choice-v2 .auth-choice-hero p{max-width:860px!important;color:rgba(255,255,255,.88)!important;font-size:clamp(16px,1.6vw,21px)!important;}
.signup-choice-card{max-width:1100px!important;margin:0 auto!important;background:#fff!important;border:1px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;padding:clamp(24px,4vw,42px)!important;display:grid!important;grid-template-columns:1fr!important;gap:22px!important;box-shadow:0 18px 60px rgba(10,31,21,.08)!important;}
.signup-type-grid{border:0!important;padding:0!important;margin:0!important;display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important;}
.signup-type-grid legend{font-weight:900!important;margin:0 0 12px!important;color:#0b1f14!important;font-size:16px!important;}
.signup-type-card{position:relative!important;display:grid!important;grid-template-columns:48px 1fr auto!important;align-items:flex-start!important;gap:14px!important;border:1.5px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;padding:18px!important;cursor:pointer!important;background:#fbfdfb!important;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease!important;min-height:124px!important;}
.signup-type-card:hover{border-color:#20a952!important;background:#f2fff6!important;}
.signup-type-card:focus-within{outline:3px solid rgba(29,185,84,.35)!important;outline-offset:2px!important;}
.signup-type-card input[type="radio"]{position:absolute!important;opacity:0!important;width:0!important;height:0!important;pointer-events:none!important;}
.signup-type-card .signup-type-card-icon{display:flex!important;align-items:center!important;justify-content:center!important;width:48px!important;height:48px!important;border-radius:var(--inrep-radius, 10px) !important;background:#e8f7ee!important;color:#0f6b34!important;flex-shrink:0!important;transition:background .18s ease,color .18s ease!important;}
.signup-type-card .signup-type-card-body{display:flex!important;flex-direction:column!important;gap:4px!important;min-width:0!important;}
.signup-type-card strong{display:block!important;font-size:16px!important;color:#07140d!important;margin:0!important;font-weight:700!important;}
.signup-type-card small{display:block!important;color:#607061!important;line-height:1.45!important;font-size:13px!important;}
.signup-type-card small.signup-type-card-note{margin-top:4px!important;color:#0f6b34!important;font-weight:600!important;font-size:12px!important;}
.signup-type-card .signup-type-card-check{display:flex!important;align-items:center!important;justify-content:center!important;width:26px!important;height:26px!important;border-radius:var(--inrep-radius, 10px) !important;border:1.5px solid #c4d4c7!important;color:transparent!important;background:#fff!important;flex-shrink:0!important;transition:all .18s ease!important;}
.signup-type-card.is-selected{border-color:#1db954!important;background:#f2fff6!important;box-shadow:0 12px 28px rgba(29,185,84,.18)!important;}
.signup-type-card.is-selected .signup-type-card-icon{background:#1db954!important;color:#fff!important;}
.signup-type-card.is-selected .signup-type-card-check{border-color:#1db954!important;background:#1db954!important;color:#fff!important;}
/* SSO block: short prompt + branded buttons */
.auth-sso-block{max-width:520px!important;margin:1.75rem auto 0!important;text-align:center!important;}
.auth-sso-block .auth-divider{display:flex!important;align-items:center!important;gap:12px!important;margin:0 0 14px!important;color:#9fb4a5!important;font-size:13px!important;}
.auth-sso-block .auth-divider::before,.auth-sso-block .auth-divider::after{content:""!important;flex:1!important;height:1px!important;background:#dfe9df!important;}
.auth-sso-block .auth-sso-prompt{margin:0 0 12px!important;color:#0b1f14!important;font-weight:600!important;font-size:14px!important;}
.auth-sso-block .auth-sso-buttons{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:10px!important;}
.auth-sso-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:10px!important;padding:11px 14px!important;background:#fff!important;border:1.5px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;color:#0b1f14!important;font-weight:600!important;font-size:14px!important;text-decoration:none!important;transition:all .18s ease!important;}
.auth-sso-btn:hover{border-color:#20a952!important;background:#f2fff6!important;color:#07140d!important;transform:translateY(-1px)!important;}
.auth-sso-btn svg{flex-shrink:0!important;}
.signup-study-level[hidden]{display:none!important;}
.selected-plan-pill{margin-top:22px!important;background:#fff!important;color:#4c5f4f!important;border-radius:var(--inrep-radius, 10px) !important;padding:14px 22px!important;text-align:center!important;font-weight:900!important;}
@media(max-width:900px){.signup-type-grid{grid-template-columns:1fr!important}.signup-type-card{min-height:auto!important}.auth-sso-block .auth-sso-buttons{grid-template-columns:1fr!important}.public-body .mkt-nav{grid-template-columns:auto auto!important}.public-body .mkt-nav-actions{display:flex!important}.public-body .mkt-nav-signin{display:inline-flex!important}.public-body .mkt-nav-signup{display:inline-flex!important}}
@media(max-width:640px){.public-body .mkt-nav-actions{display:none!important}.preprint-hero-polished{min-height:auto!important;padding-top:70px!important}.signup-choice-v2{padding:16px!important}.signup-choice-v2 .auth-choice-hero,.signup-choice-card{border-radius:var(--inrep-radius, 10px) !important}.public-body .btn.secondary,.public-body .btn.btn-secondary,.public-body .btn-outline-white,.public-body .btn-hero-secondary{width:100%!important}}

/* 20260511: public navigation restored + preprint workflow polish */
.public-body .mkt-nav{grid-template-columns:auto minmax(0,1fr) auto auto!important;gap:18px!important;min-height:68px!important}
.public-body .mkt-nav-items{display:flex!important;align-items:center!important;justify-content:center!important;gap:6px!important;min-width:0!important}
.public-body .mkt-nav-item{font-size:13px!important;font-weight:800!important;color:#2f4538!important;padding:9px 10px!important;border-radius:var(--inrep-radius, 10px) !important;letter-spacing:-.01em!important}
.public-body .mkt-nav-item:hover,.public-body .mkt-nav-item[aria-current="page"]{background:#eef8f0!important;color:#0a8f3c!important;text-decoration:none!important}
.public-body .mkt-nav-actions{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:12px!important;white-space:nowrap!important}
.public-body .mkt-nav-toggle{display:none!important}
.public-body .mkt-mobile-links{display:grid!important;gap:8px!important;padding:8px 0!important}
.public-body .mkt-mobile-links a{font-size:15px!important;padding:13px 14px!important;border:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;color:#163322!important}
.public-body .mkt-mobile-links a[aria-current="page"]{background:#eef8f0!important;color:#0a8f3c!important;border-color:#bfe8ca!important}
.public-body .btn.secondary,.public-body .btn.btn-secondary,.public-body .btn-outline-white,.public-body .btn-hero-secondary{background:#fff!important;border:1.5px solid #cde8d3!important;color:#07883a!important;box-shadow:0 12px 30px rgba(10,31,21,.06)!important;text-decoration:none!important}
.public-body .btn.secondary:hover,.public-body .btn.btn-secondary:hover,.public-body .btn-outline-white:hover,.public-body .btn-hero-secondary:hover{background:#effaf1!important;border-color:#1db954!important;color:#063d1d!important}
.preprint-show-hero{padding:clamp(70px,8vw,118px) 24px clamp(54px,7vw,92px)!important;background:linear-gradient(180deg,#f6fff8 0%,#fff 78%)!important;text-align:center!important}
.preprint-show-hero-inner{width:min(980px,100%)!important;margin:0 auto!important;display:grid!important;justify-items:center!important;gap:18px!important}
.preprint-show-hero h1{font-family:var(--font-display)!important;font-size:clamp(38px,6vw,76px)!important;line-height:.98!important;letter-spacing:-.07em!important;max-width:950px!important;margin:0!important;color:#060807!important}
.preprint-show-hero p{max-width:780px!important;margin:0!important;color:#58705f!important;font-size:clamp(16px,2vw,21px)!important;line-height:1.75!important}
.preprint-status-row{display:flex!important;justify-content:center!important;gap:10px!important;flex-wrap:wrap!important;margin-top:4px!important}
.preprint-status-row span{display:inline-flex!important;align-items:center!important;padding:8px 12px!important;border-radius:var(--inrep-radius, 10px) !important;background:#f0faf2!important;border:1px solid #cbeed4!important;color:#116b32!important;font-size:12px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.06em!important}
.preprint-show-section,.preprint-feedback-section{padding:clamp(54px,6vw,88px) 24px!important;background:#f4f8f2!important}
.preprint-feedback-section{padding-top:24px!important}
.preprint-show-grid,.preprint-feedback-grid{width:min(1120px,100%)!important;margin:0 auto!important;display:grid!important;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr)!important;gap:24px!important;align-items:start!important}
.preprint-panel{background:#fff!important;border:1px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;padding:clamp(24px,3vw,34px)!important;box-shadow:0 18px 50px rgba(8,36,20,.08)!important;min-width:0!important;text-align:left!important}
.preprint-panel h2,.preprint-panel h3{font-family:var(--font-display)!important;font-size:clamp(24px,3vw,34px)!important;line-height:1.1!important;margin:10px 0 14px!important;color:#08110b!important;letter-spacing:-.04em!important}
.preprint-panel p{color:#5b6f60!important;line-height:1.7!important;margin:0 0 16px!important}
.preprint-meta-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;margin:22px 0 0!important}
.preprint-meta-grid div{border:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important;padding:14px!important;background:#fbfdfb!important;min-width:0!important}
.preprint-meta-grid dt{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:#66806d!important;font-weight:900!important;margin-bottom:6px!important}
.preprint-meta-grid dd{margin:0!important;font-weight:800!important;color:#102518!important;overflow-wrap:anywhere!important}
.preprint-version-list{list-style:none!important;margin:18px 0 0!important;padding:0!important;display:grid!important;gap:12px!important}
.preprint-version-list li{border:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfb!important;padding:14px!important;display:grid!important;gap:5px!important}
.preprint-version-list strong{color:#08110b!important}.preprint-version-list span{color:#0a8f3c!important;font-weight:900!important}.preprint-version-list small{color:#6a7c70!important}.preprint-version-list p{margin:4px 0 0!important}
.preprint-feedback-section .section-heading{max-width:760px!important;margin:0 auto 28px!important;text-align:center!important}.preprint-feedback-section .section-heading p{color:#5b6f60!important;line-height:1.65!important;margin-top:8px!important}
.preprint-comment-form{display:grid!important;grid-template-columns:1fr 1fr!important;gap:16px!important}.preprint-comment-form label{display:grid!important;gap:7px!important;font-weight:850!important;color:#102518!important}.preprint-comment-form .full-span{grid-column:1/-1!important}.preprint-comment-form input,.preprint-comment-form textarea{width:100%!important;min-height:48px!important;border:1px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;padding:12px 14px!important;background:#fff!important;font:inherit!important;color:#102518!important}.preprint-comment-form textarea{min-height:140px!important;resize:vertical!important}.preprint-comment-form button{width:max-content!important;min-width:190px!important;justify-content:center!important}
.preprint-comment-list{display:grid!important;gap:14px!important;margin-top:14px!important}.preprint-comment{border-top:1px solid #edf3ee!important;padding-top:14px!important}.preprint-comment strong{display:block!important;color:#102518!important}.preprint-comment small{color:#708476!important}.preprint-comment p{margin:10px 0!important}.preprint-comment em{display:block!important;color:#617266!important;font-size:13px!important}.empty-copy{padding:18px!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfb!important;border:1px dashed #dce8de!important;color:#617266!important}
@media (max-width:1180px){.public-body .mkt-nav{padding-inline:24px!important}.public-body .mkt-nav-items{gap:2px!important}.public-body .mkt-nav-item{font-size:12px!important;padding-inline:7px!important}}
@media (max-width:1024px){.public-body .mkt-nav{grid-template-columns:auto minmax(0,1fr) auto!important}.public-body .mkt-nav-items,.public-body .mkt-nav-actions{display:none!important}.public-body .mkt-nav-toggle{display:inline-grid!important;justify-self:end!important}.preprint-show-grid,.preprint-feedback-grid{grid-template-columns:1fr!important}.preprint-meta-grid{grid-template-columns:1fr 1fr!important}}
@media (max-width:640px){.preprint-show-hero{padding-inline:18px!important}.preprint-show-hero h1{font-size:clamp(34px,12vw,52px)!important}.preprint-meta-grid,.preprint-comment-form{grid-template-columns:1fr!important}.preprint-comment-form button{width:100%!important}.preprint-show-section,.preprint-feedback-section{padding-inline:16px!important}.preprint-panel{border-radius:var(--inrep-radius, 10px) !important}.preprint-status-row span{width:100%!important;justify-content:center!important}.preprint-show-hero .hero-ctas .btn{width:100%!important;justify-content:center!important}}

/* 20260511: final public nav spacing, dashboard-only preprints, mobile hamburger polish */
@media (min-width:1025px){
  .public-body .mkt-nav{
    grid-template-columns:auto minmax(430px,1fr) minmax(260px,360px) auto!important;
    gap:14px!important;
  }
  .public-body .mkt-nav-search{
    width:100%!important;
    max-width:360px!important;
    min-width:260px!important;
    justify-self:end!important;
  }
  .public-body .mkt-nav-actions{
    gap:6px!important;
    margin-left:0!important;
  }
  .public-body .mkt-nav-signin{
    padding-inline:10px!important;
  }
  .public-body .mkt-nav-signup{
    margin-left:0!important;
  }
}
@media (max-width:1320px) and (min-width:1025px){
  .public-body .mkt-nav{grid-template-columns:auto minmax(360px,1fr) minmax(220px,300px) auto!important;gap:10px!important;padding-inline:24px!important;}
  .public-body .mkt-nav-search{min-width:220px!important;max-width:300px!important;}
  .public-body .mkt-nav-item{padding-inline:7px!important;font-size:12px!important;}
}
@media (max-width:1120px) and (min-width:1025px){
  .public-body .mkt-nav-search{display:flex!important;min-width:190px!important;max-width:240px!important;}
}
.public-body .mkt-nav-toggle{
  border:0!important;
  background:#f2faf4!important;
  color:#0b311b!important;
  width:46px!important;
  height:46px!important;
  border-radius:var(--inrep-radius, 10px) !important;
  box-shadow:none!important;
}
.public-body .mkt-nav-toggle:hover{
  background:#e7f7ec!important;
  transform:translateY(-1px)!important;
}
.public-body .mkt-nav-toggle svg{
  width:26px!important;
  height:26px!important;
}
@media (max-width:1024px){
  .public-body .mkt-nav{grid-template-columns:auto 1fr auto!important;gap:14px!important;}
  .public-body .mkt-nav-toggle{display:inline-grid!important;place-items:center!important;}
}
.preprint-dashboard-page,.preprint-submit-page{display:grid!important;gap:26px!important;}
.preprint-dashboard-page .split-head,.preprint-submit-page .split-head{align-items:flex-start!important;gap:18px!important;}
.preprint-dashboard-page .split-head h1,.preprint-submit-page .split-head h1{margin:6px 0 8px!important;font-family:var(--font-display)!important;letter-spacing:-.045em!important;}
.preprint-dashboard-process{grid-template-columns:repeat(4,minmax(0,1fr))!important;width:100%!important;margin:0!important;}
.preprint-dashboard-grid{width:100%!important;margin:0!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;}
.preprint-card-actions{display:flex!important;gap:10px!important;margin-top:auto!important;}
.preprint-submit-form{display:grid!important;gap:18px!important;max-width:980px!important;}
.preprint-submit-form label{display:grid!important;gap:8px!important;font-weight:800!important;color:#102518!important;}
.preprint-submit-form input,.preprint-submit-form select,.preprint-submit-form textarea{width:100%!important;border:1px solid #dfe9df!important;border-radius:var(--inrep-radius, 10px) !important;padding:12px 14px!important;background:#fff!important;min-height:48px!important;font:inherit!important;color:#102518!important;}
.preprint-submit-form input[readonly]{background:#f7faf7!important;color:#4d6254!important;}
.preprint-submit-form textarea{min-height:180px!important;resize:vertical!important;}
@media (max-width:1100px){.preprint-dashboard-process,.preprint-dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}
@media (max-width:680px){.preprint-dashboard-process,.preprint-dashboard-grid,.form-row-2{grid-template-columns:1fr!important}.preprint-dashboard-page .split-head,.preprint-submit-page .split-head{display:grid!important}.preprint-card-actions .btn,.preprint-submit-form .form-actions .btn{width:100%!important;justify-content:center!important}}

/* 20260511 investor demo UX workflow upgrades */
.student-register-wizard,.submission-wizard-form{display:block!important;max-width:1040px!important;width:100%!important;margin-inline:auto!important;padding:26px!important;border-radius:var(--inrep-radius, 10px) !important}
.student-wizard-hero{max-width:1040px!important;margin-inline:auto!important}.wizard-progress{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(130px,1fr))!important;gap:10px!important;list-style:none!important;padding:0!important;margin:0 0 24px!important}.wizard-progress li{display:flex!important;align-items:center!important;gap:8px!important;padding:10px 12px!important;border:1px solid #e3ece4!important;border-radius:var(--inrep-radius, 10px) !important;background:#f8fbf8!important;color:#637568!important;font-weight:850!important;font-size:13px!important}.wizard-progress li span{display:inline-grid!important;place-items:center!important;width:25px!important;height:25px!important;border-radius:var(--inrep-radius, 10px) !important;background:#e7f4eb!important;color:#1a6b36!important;font-size:12px!important}.wizard-progress li.active{background:#eaf8ee!important;border-color:#bfe4c9!important;color:#0c321a!important}.wizard-progress li.active span{background:#0f8f3e!important;color:#fff!important}.wizard-step{display:none!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:18px!important}.wizard-step.active{display:grid!important}.wizard-step .full,.wizard-step .span-full{grid-column:1/-1!important}.wizard-step label{display:grid!important;gap:8px!important;font-weight:850!important;color:#102518!important}.wizard-step input,.wizard-step select,.wizard-step textarea{width:100%!important;border:1px solid #dae6dc!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;color:#102518!important;min-height:48px!important;padding:12px 14px!important;font:inherit!important}.wizard-step textarea{min-height:160px!important;resize:vertical!important}.wizard-actions{display:flex!important;justify-content:space-between!important;gap:12px!important;margin-top:6px!important}.wizard-actions .btn{min-width:130px!important;justify-content:center!important}.school-email-domain-note{border:1px dashed #b7dec1!important;background:#f0faf3!important;color:#235933!important;border-radius:var(--inrep-radius, 10px) !important;padding:12px 14px!important;font-weight:750!important}.is-invalid{border-color:#dc2626!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important}
.submission-checklist-row{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:16px!important;margin-bottom:18px!important}.submission-quality-card,.submission-draft-card{display:grid!important;gap:8px!important}.submission-quality-card strong,.submission-draft-card strong{font-size:34px!important;line-height:1!important;color:#0c321a!important}.submission-quality-card ul{margin:0!important;padding-left:18px!important;color:#9a3412!important}.access-policy-cards{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:12px!important}.access-policy-card{position:relative!important;display:grid!important;gap:7px!important;border:1px solid #dbe8dd!important;background:#fff!important;border-radius:var(--inrep-radius, 10px) !important;padding:15px!important;cursor:pointer!important;min-height:132px!important;transition:.18s ease!important}.access-policy-card input{position:absolute!important;top:12px!important;right:12px!important;width:18px!important;height:18px!important;min-height:auto!important;padding:0!important}.access-policy-card span{width:max-content!important;max-width:100%!important;border-radius:var(--inrep-radius, 10px) !important;padding:3px 8px!important;background:#eef8f1!important;color:#147537!important;font-size:11px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.06em!important}.access-policy-card strong{font-size:16px!important;color:#0d2616!important}.access-policy-card small{line-height:1.45!important;color:#5b6f60!important}.access-policy-card.is-selected{border-color:#10a34a!important;background:#f0faf3!important;box-shadow:0 10px 26px rgba(16,163,74,.12)!important}.embargo-field{display:none!important}.embargo-field.is-visible{display:grid!important}.submission-preview dl{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;margin:0!important}.submission-preview div{padding:12px 14px!important;border:1px solid #e4eee6!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfb!important}.submission-preview dt{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.08em!important;color:#6b7b70!important;font-weight:900!important}.submission-preview dd{margin:4px 0 0!important;color:#102518!important;font-weight:800!important;overflow-wrap:anywhere!important}
.comfortable-table-wrap{overflow:auto!important}.comfortable-table{border-collapse:separate!important;border-spacing:0 10px!important;min-width:860px!important}.comfortable-table thead th{background:#f7faf7!important;color:#5f7566!important;font-size:12px!important;text-transform:uppercase!important;letter-spacing:.06em!important;padding:12px 16px!important}.comfortable-table tbody tr{background:#fff!important;box-shadow:0 8px 22px rgba(16,24,40,.05)!important}.comfortable-table td{padding:16px!important;border-top:1px solid #edf3ee!important;border-bottom:1px solid #edf3ee!important;vertical-align:top!important}.comfortable-table td:first-child{border-left:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important}.comfortable-table td:last-child{border-right:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important}.wide-cell{min-width:320px!important}.block-muted{display:block!important;margin-top:7px!important;color:#9a3412!important;max-width:260px!important}.score-pill{display:inline-flex!important;align-items:center!important;justify-content:center!important;min-width:54px!important;border-radius:var(--inrep-radius, 10px) !important;padding:6px 10px!important;font-size:12px!important;font-weight:900!important}.score-pill.good{background:#dcfce7!important;color:#166534!important}.score-pill.warn{background:#fef3c7!important;color:#92400e!important}.score-pill.bad{background:#fee2e2!important;color:#991b1b!important}.correction-alert-stack{display:grid!important;gap:12px!important;margin-bottom:16px!important}.correction-alert-card{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:16px!important}.correction-alert-card p{margin:5px 0 0!important}.correction-center-grid{align-items:start!important}.compact-detail-list{display:grid!important;gap:10px!important;margin:14px 0!important}.compact-detail-list div{display:flex!important;justify-content:space-between!important;gap:12px!important;border-bottom:1px solid #edf3ee!important;padding-bottom:8px!important}.compact-detail-list dt{color:#6b7b70!important;font-weight:850!important}.compact-detail-list dd{margin:0!important;text-align:right!important}.metadata-action-list{display:flex!important;flex-wrap:wrap!important;gap:8px!important}.metadata-check{display:inline-flex!important;border-radius:var(--inrep-radius, 10px) !important;padding:6px 10px!important;font-size:12px!important;font-weight:850!important}.metadata-check.pass{background:#ecfdf3!important;color:#166534!important}.metadata-check.fail{background:#fff7ed!important;color:#9a3412!important}.correction-note-list{display:grid!important;gap:12px!important}.correction-note-list article{border:1px solid #fde5e5!important;background:#fff7f7!important;border-radius:var(--inrep-radius, 10px) !important;padding:13px!important}.correction-note-list p{margin:6px 0!important}.correction-resubmit-form{margin-top:16px!important}
.enhanced-review-list{display:grid!important;grid-template-columns:1fr!important;gap:15px!important}.enhanced-review-card{border:1px solid #e4eee6!important;border-radius:var(--inrep-radius, 10px) !important;padding:18px!important;background:#fff!important;box-shadow:0 14px 38px rgba(16,24,40,.06)!important}.review-preview-details{border:1px solid #edf3ee!important;border-radius:var(--inrep-radius, 10px) !important;background:#fbfdfb!important;padding:12px 14px!important;margin:14px 0!important}.review-preview-details summary{cursor:pointer!important;font-weight:900!important;color:#0d3b20!important}.review-preview-grid{display:grid!important;grid-template-columns:2fr 1fr!important;gap:16px!important;margin-top:12px!important}.review-preview-grid p{color:#556a5c!important;line-height:1.6!important}.review-preview-grid dl{display:grid!important;gap:8px!important;margin:0!important}.review-preview-grid dt{font-size:11px!important;text-transform:uppercase!important;letter-spacing:.07em!important;color:#6c7d72!important;font-weight:900!important}.review-preview-grid dd{margin:0!important;font-weight:800!important}.sticky-bulk-bar{position:sticky!important;top:0!important;z-index:3!important}.admin-notification-bell{position:relative!important}.admin-notification-bell .admin-count-badge{position:absolute!important;top:-5px!important;right:-5px!important}
.public-review-panel{margin-top:18px!important}.table-actions-cell{white-space:nowrap!important}.form-actions{display:flex!important;gap:10px!important;align-items:center!important}.block{display:block!important}
@media (max-width:900px){.wizard-step,.submission-checklist-row,.submission-preview dl,.review-preview-grid{grid-template-columns:1fr!important}.access-policy-cards{grid-template-columns:1fr 1fr!important}.correction-alert-card{display:grid!important}.comfortable-table{min-width:760px!important}}
@media (max-width:640px){.student-register-wizard,.submission-wizard-form{padding:18px!important;border-radius:var(--inrep-radius, 10px) !important}.wizard-progress{grid-template-columns:1fr 1fr!important}.wizard-actions{display:grid!important}.wizard-actions .btn{width:100%!important}.access-policy-cards{grid-template-columns:1fr!important}.submission-quality-card strong,.submission-draft-card strong{font-size:28px!important}}
.mini-progress{height:8px!important;border-radius:var(--inrep-radius, 10px) !important;background:#edf3ef!important;overflow:hidden!important;width:120px!important}.mini-progress span{display:block!important;height:100%!important;border-radius:var(--inrep-radius, 10px) !important;background:#16a34a!important;transition:width .25s ease!important}

/* 20260511 onboarding / review polish */
.onboarding-checklist{
    position:sticky;
    top:92px;
    z-index:3;
    margin-top:16px;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 18px 45px rgba(15,23,42,.07);
}
.setup-check-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;max-width:760px}
.setup-check{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border-radius:var(--inrep-radius, 10px) !important;font-size:.82rem;font-weight:700;border:1px solid rgba(148,163,184,.35);background:#fff;color:#334155;white-space:nowrap}
.setup-check b{display:grid;place-items:center;width:18px;height:18px;border-radius:var(--inrep-radius, 10px) !important;font-size:.72rem}
.setup-check.is-done{border-color:rgba(22,163,74,.25);background:#f0fdf4;color:#166534}
.setup-check.is-done b{background:#16a34a;color:#fff}
.setup-check.is-pending{border-color:rgba(245,158,11,.32);background:#fffbeb;color:#92400e}
.setup-check.is-pending b{background:#f59e0b;color:#fff}
@media (max-width:900px){.onboarding-checklist{position:static;display:block}.setup-check-grid{justify-content:flex-start;margin-top:12px}}


/* 20260511 hard fix: session-aware public nav + tighter public CTA spacing */
.public-body .mkt-nav{
  grid-template-columns:auto minmax(0,1fr) minmax(260px,340px) auto!important;
  gap:14px!important;
}
.public-body .mkt-nav-search{
  width:100%!important;
  min-width:260px!important;
  max-width:340px!important;
}
.public-body .mkt-nav-actions{
  gap:6px!important;
  justify-content:flex-end!important;
}
.public-body .mkt-nav-actions .mkt-nav-signin{
  min-width:0!important;
  width:auto!important;
  padding:8px 10px!important;
}
.public-body .mkt-nav-actions .mkt-nav-signup{
  min-width:0!important;
  width:auto!important;
  padding:9px 16px!important;
  margin-left:0!important;
}
.public-body .mkt-nav-actions .mkt-nav-signup[href$="/dashboard"],
.public-body .mkt-nav-actions .mkt-nav-signup[href="/dashboard"]{
  padding-inline:18px!important;
}
.public-body .mkt-nav-toggle{
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  width:46px!important;
  height:46px!important;
  border-radius:var(--inrep-radius, 10px) !important;
}
.public-body .mkt-nav-toggle svg{
  width:26px!important;
  height:26px!important;
}
.public-body .mkt-nav-toggle:hover{
  background:#eef8f0!important;
}
@media (max-width:1280px){
  .public-body .mkt-nav{grid-template-columns:auto minmax(0,1fr) minmax(220px,280px) auto!important;}
  .public-body .mkt-nav-search{min-width:220px!important;max-width:280px!important;}
}
@media (max-width:1120px){
  .public-body .mkt-nav{grid-template-columns:auto minmax(0,1fr) auto!important;}
  .public-body .mkt-nav-search{display:none!important;}
}
@media (max-width:1024px){
  .public-body .mkt-nav{grid-template-columns:auto 1fr auto!important;}
  .public-body .mkt-nav-items,.public-body .mkt-nav-actions{display:none!important;}
  .public-body .mkt-nav-toggle{display:inline-grid!important;justify-self:end!important;place-items:center!important;}
}


/* investor UX final corrections */
.public-body .mkt-hero-copy > .hero-ctas {
  justify-content: flex-start !important;
  align-items: center !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  width: auto !important;
}
.final-cta .hero-ctas { justify-content: center !important; margin-left: auto !important; margin-right: auto !important; }
.repository-browser-enhanced { display:grid; grid-template-columns:minmax(240px,300px) minmax(0,1fr); gap:24px; max-width:1240px; margin:0 auto; padding:32px 20px 80px; }
.repository-facet-sidebar { align-self:start; position:sticky; top:94px; display:flex; flex-direction:column; gap:14px; }
.repository-facet-sidebar details { border:1px solid var(--border-light); border-radius:var(--inrep-radius, 10px) !important; padding:10px 12px; background:#fff; }
.repository-facet-sidebar summary { cursor:pointer; font-weight:800; color:var(--text-dark); }
.facet-option-grid { display:grid; gap:8px; margin-top:10px; }
.facet-option-grid label { display:flex; align-items:center; gap:8px; font-size:13px; }
.repository-results-pane { min-width:0; }
.repository-results-head { display:flex; align-items:center; justify-content:space-between; gap:14px; margin:0 0 18px; }
.view-toggle { display:flex; gap:6px; flex:none; }
.repository-grid-list { display:grid; grid-template-columns:1fr !important; }
.repository-grid-list .repository-card { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:8px 18px; }
.repository-grid mark { background:#fff3b0; color:#17331f; padding:0 2px; border-radius:var(--inrep-radius, 10px) !important; }
.as-button { background:transparent; border:0; padding:0; cursor:pointer; color:inherit; font:inherit; }
.record-preview-modal[hidden] { display:none; }
.record-preview-modal { position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.45); display:grid; place-items:center; padding:20px; }
.record-preview-modal section { width:min(640px,100%); background:#fff; border-radius:var(--inrep-radius, 10px) !important; padding:24px; box-shadow:0 24px 80px rgba(0,0,0,.25); }
.public-pagination { display:flex; align-items:center; justify-content:center; gap:10px; margin-top:22px; }
.public-pagination .disabled { opacity:.45; pointer-events:none; }
.sla-pill { display:inline-flex; align-items:center; justify-content:center; padding:4px 8px; border-radius:var(--inrep-radius, 10px) !important; font-size:12px; font-weight:800; }
.sla-pill.good { background:#ecfdf3; color:#027a48; }
.sla-pill.warn { background:#fff7e6; color:#a15c00; }
.sla-pill.bad { background:#fee4e2; color:#b42318; }
.pdf-preview-box { border:1px dashed var(--border-light); border-radius:var(--inrep-radius, 10px) !important; padding:12px; background:#f8fbf9; font-size:13px; color:var(--text-muted); }
.pdf-preview-box iframe { width:100%; height:360px; border:0; border-radius:var(--inrep-radius, 10px) !important; margin-top:10px; background:#fff; }
.coauthor-builder { border:1px solid var(--border-light); border-radius:var(--inrep-radius, 10px) !important; padding:14px; background:#fbfdfb; }
.coauthor-row { display:grid; grid-template-columns:1fr 1fr auto; gap:10px; margin-top:10px; }
.command-palette-modal[hidden] { display:none; }
.command-palette-modal { position:fixed; inset:0; z-index:10000; background:rgba(3,20,12,.55); display:grid; place-items:start center; padding-top:8vh; }
.command-palette-card { width:min(720px,calc(100% - 28px)); background:#fff; border-radius:var(--inrep-radius, 10px) !important; box-shadow:0 24px 90px rgba(0,0,0,.28); overflow:hidden; }
.command-palette-card header { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--border-light); }
.command-palette-input { width:100%; border:0; outline:0; padding:18px 20px; font-size:18px; font-weight:700; }
.command-palette-results { max-height:56vh; overflow:auto; padding:10px; }
.command-palette-results a { display:flex; justify-content:space-between; gap:14px; padding:12px; border-radius:var(--inrep-radius, 10px) !important; color:var(--text-dark); text-decoration:none; }
.command-palette-results a:hover,.command-palette-results a.is-active { background:#effaf1; }
.command-palette-results small { color:var(--text-muted); }
.admin-sidebar-pin { opacity:.45; }
.admin-sidebar-link.is-pinned .admin-sidebar-pin { opacity:1; color:var(--accent-green); }
@media (max-width: 860px){
  .repository-browser-enhanced { grid-template-columns:1fr; padding-inline:16px; }
  .repository-facet-sidebar { position:static; }
  .repository-results-head { align-items:flex-start; flex-direction:column; }
  .repository-grid-list .repository-card { grid-template-columns:1fr; }
  .coauthor-row { grid-template-columns:1fr; }
}
@media (max-width:640px){
  .public-body .mkt-hero-copy > .hero-ctas { flex-direction:column !important; width:100% !important; }
  .public-body .mkt-hero-copy > .hero-ctas a { width:100% !important; justify-content:center !important; }
}

/* 2026-05-11 surgical UX fixes: routing separation, tables, mobile nav, links, analytics, customizer */
.hero-eyebrow,
.section-eyebrow,
.eyebrow {
  margin-bottom: 14px !important;
}
.hero-eyebrow + h1,
.hero-eyebrow + h2,
.hero-eyebrow + h3,
.section-eyebrow + h1,
.section-eyebrow + h2,
.eyebrow + h1,
.eyebrow + h2,
.eyebrow + h3 {
  margin-top: 8px !important;
}
.status-badge.unread,
.status-badge.pending {
  background: #fff7ed !important;
  color: #9a3412 !important;
  border: 1px solid #fed7aa !important;
}
.notification-row.is-unread {
  background: #fffaf2 !important;
  border: 1px solid #fed7aa !important;
  box-shadow: inset 4px 0 0 #f97316;
}
.table-bulk-bar,
.inline-actions,
.table-actions,
.review-action-stack,
.action-button-row,
.admin-actions,
.filter-actions {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
.table-actions form,
.inline-actions form,
.review-action-stack form,
.table-bulk-bar form,
.action-button-row form {
  margin: 0 !important;
  display: inline-flex !important;
}
.table-bulk-bar {
  padding: 12px !important;
  border: 1px solid #dbe7df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fcf9 !important;
  margin-bottom: 12px !important;
}
.table-bulk-bar input,
.table-bulk-bar select {
  min-height: 34px !important;
  max-width: 260px !important;
}
.admin-table,
.admin-table-wrap table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
  width: 100% !important;
  table-layout: auto !important;
}
.admin-table th,
.admin-table td,
.admin-table-wrap table th,
.admin-table-wrap table td {
  padding: 10px 12px !important;
  vertical-align: top !important;
  line-height: 1.38 !important;
}
.admin-table th,
.admin-table-wrap table th {
  white-space: nowrap !important;
}
.admin-table td:last-child,
.admin-table-wrap table td:last-child,
.review-actions-cell,
.cell-action,
.table-actions {
  min-width: 170px !important;
}
.compact-table th,
.compact-table td { padding: 9px 10px !important; }
.review-actions-cell .btn,
.table-actions .btn,
.inline-actions .btn,
.webhook-test-btn,
.webhook-save-btn {
  min-height: 34px !important;
  color: #fff !important;
  border-color: #16a34a !important;
  background: #16a34a !important;
  box-shadow: none !important;
}
.review-actions-cell .btn.danger,
.table-actions .btn.danger,
.inline-actions .btn.danger,
.btn.danger {
  background: #dc2626 !important;
  border-color: #dc2626 !important;
  color: #fff !important;
}
.btn.btn-secondary,
.btn.secondary {
  background: #ffffff !important;
  color: #0f5132 !important;
  border: 1px solid #9bd6ae !important;
}
.webhook-test-btn,
.webhook-save-btn { font-weight: 800 !important; }
.submission-expiry-box {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid #dbe7df;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fcf9;
}
.copy-feedback { min-height: 18px; color: #166534; font-weight: 700; }
.analytics-chart-grid { align-items: stretch; }
.analytics-chart-card canvas,
.mini-chart {
  display: block;
  width: 100% !important;
  max-width: 100%;
  border: 1px solid #e2e8f0;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(180deg,#fff,#f8fafc);
  padding: 10px;
}
.institution-public-logo {
  width: 78px;
  height: 78px;
  object-fit: contain;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 18px 45px rgba(0,0,0,.16);
  margin-bottom: 14px;
}
.institution-template-modern .project-public-card,
.institution-template-modern .institution-rich-card { border-radius: var(--inrep-radius, 10px) !important; box-shadow: 0 18px 50px rgba(15,23,42,.08); }
.institution-template-editorial .institution-hero { text-align: left; align-items: flex-start; }
.institution-template-visual .institution-hero { min-height: 560px; justify-content: center; }
.institution-template-minimal .institution-rich-overview,
.institution-template-minimal .institution-guidance-section { display: none; }
.institution-custom-landing-wrap { padding: 28px clamp(18px,4vw,48px); }
.institution-custom-landing-frame {
  width: 100%;
  min-height: 720px;
  border: 1px solid #dbe7df;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 22px 60px rgba(15,23,42,.08);
}
.custom-landing-panel textarea { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.impersonation-floating-stop {
  position: fixed;
  bottom: 24px;
  right: 24px;
  top: auto;
  left: auto;
  z-index: 2147483000;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #dc2626;
  color: #fff;
  box-shadow: 0 22px 60px rgba(220,38,38,.45), 0 2px 4px rgba(0,0,0,.12);
  animation: impersonation-pulse 2.4s ease-in-out infinite;
}
.impersonation-floating-stop .impersonation-floating-stop-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.01em;
}
.impersonation-floating-stop-dot {
  width: 10px;
  height: 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 0 0 0 rgba(255,255,255,.7);
  animation: impersonation-dot 1.6s ease-in-out infinite;
}
.impersonation-floating-stop .btn {
  min-height: 38px !important;
  padding: 8px 14px !important;
  background: #fff !important;
  color: #b91c1c !important;
  border: 0 !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.impersonation-floating-stop .btn:hover,
.impersonation-floating-stop .btn:focus-visible {
  background: #fee2e2 !important;
  color: #7f1d1d !important;
  outline: 2px solid #fff !important;
  outline-offset: 2px !important;
}
.impersonation-floating-stop .inline-form { margin: 0; padding: 0; }
@keyframes impersonation-pulse {
  0%,100% { box-shadow: 0 22px 60px rgba(220,38,38,.45), 0 2px 4px rgba(0,0,0,.12), 0 0 0 0 rgba(220,38,38,.4); }
  50% { box-shadow: 0 22px 60px rgba(220,38,38,.45), 0 2px 4px rgba(0,0,0,.12), 0 0 0 12px rgba(220,38,38,0); }
}
@keyframes impersonation-dot {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,255,255,.75); }
  50% { box-shadow: 0 0 0 6px rgba(255,255,255,0); }
}
@media (prefers-reduced-motion: reduce) {
  .impersonation-floating-stop,
  .impersonation-floating-stop-dot { animation: none !important; }
}
@media (max-width: 640px) {
  .impersonation-floating-stop {
    bottom: 84px;
    right: 12px;
    left: 12px;
    padding: 10px 12px;
    gap: 8px;
    justify-content: space-between;
  }
  .impersonation-floating-stop .impersonation-floating-stop-label { font-size: 12px; }
}
@media (max-width: 1023px) {
  .admin-shell,
  body.admin-sidebar-collapsed .admin-shell,
  body:not(.admin-sidebar-collapsed) .admin-shell {
    grid-template-columns: minmax(0,1fr) !important;
  }
  .admin-sidebar {
    width: min(88vw, 360px) !important;
    max-width: min(88vw, 360px) !important;
    transform: translateX(-105%) !important;
    left: 0 !important;
    right: auto !important;
    border-radius: var(--inrep-radius, 10px) !important;
    box-shadow: 18px 0 55px rgba(15,23,42,.22) !important;
  }
  body.admin-sidebar-open .admin-sidebar { transform: translateX(0) !important; }
  .admin-sidebar-overlay {
    background: rgba(15,23,42,.18) !important;
    backdrop-filter: blur(1px) !important;
  }
  .admin-sidebar-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }
  .admin-sidebar-close {
    margin-left: auto !important;
    width: 42px !important;
    height: 42px !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: rgba(255,255,255,.10) !important;
  }
  .admin-sidebar-close svg { width: 22px !important; height: 22px !important; }
  .admin-topbar { grid-template-columns: auto auto minmax(0,1fr) auto !important; }
  .admin-topbar-actions .admin-topbar-action-labeled { display: none !important; }
  .admin-main { padding-inline: 14px !important; }
  .admin-table-wrap { overflow: visible !important; }
  .admin-table-wrap table.admin-table,
  .admin-table-wrap .admin-table {
    min-width: 0 !important;
  }
  .admin-table-wrap .admin-table thead { display: none !important; }
  .admin-table-wrap .admin-table tr {
    display: grid !important;
    gap: 8px !important;
    padding: 12px !important;
    margin-bottom: 12px !important;
    border: 1px solid #dbe7df !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff !important;
  }
  .admin-table-wrap .admin-table td {
    display: flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
    border-bottom: 1px solid #eef2f7 !important;
    padding: 8px 0 !important;
  }
  .admin-table-wrap .admin-table td:last-child { border-bottom: 0 !important; justify-content: flex-start !important; }
  .table-actions,
  .review-action-stack,
  .inline-actions { width: 100% !important; }
  .table-actions .btn,
  .review-action-stack .btn,
  .inline-actions .btn { flex: 1 1 auto !important; justify-content: center !important; }
}


/* 2026-05-11 deep cross-check corrections */
.admin-sidebar-close{display:none;}
.admin-count-badge,.notification-count-badge{background:#dc2626!important;color:#fff!important;border:2px solid #fff!important;box-shadow:0 8px 18px rgba(220,38,38,.25)!important;}
.status-badge.unread{background:#fee2e2!important;color:#991b1b!important;border:1px solid #fecaca!important;box-shadow:none!important;}
.notification-row.is-unread{background:#fff7ed!important;border-color:#fdba74!important;box-shadow:inset 5px 0 0 #f97316!important;}
.hero-eyebrow,.section-eyebrow,.eyebrow{display:inline-flex;margin-bottom:20px!important;}
.hero-eyebrow + h1,.hero-eyebrow + h2,.hero-eyebrow + h3,.section-eyebrow + h1,.section-eyebrow + h2,.eyebrow + h1,.eyebrow + h2,.eyebrow + h3{margin-top:0!important;}
.users-management-page .table-bulk-bar{align-items:center!important;justify-content:flex-start!important;}
.users-management-page .table-bulk-bar .btn{white-space:nowrap!important;}
.review-action-stack{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(138px,1fr))!important;align-items:stretch!important;gap:8px!important;min-width:min(460px,100%)!important;}
.review-action-stack .review-mini-form{display:grid!important;grid-template-columns:1fr!important;gap:6px!important;}
.review-action-stack input,.review-action-stack select{width:100%!important;min-width:0!important;max-width:100%!important;}
.review-actions-cell{min-width:420px!important;}
.library-review-table td{vertical-align:top!important;}
.inline-form-grid{display:grid!important;grid-template-columns:repeat(2,minmax(110px,1fr))!important;gap:8px!important;min-width:330px!important;}
.inline-form-grid .btn{grid-column:1/-1!important;}
.webhook-test-btn,.webhook-save-btn{background:#0f766e!important;border:1px solid #0f766e!important;color:#fff!important;border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 10px 24px rgba(15,118,110,.20)!important;}
.webhook-test-btn:hover,.webhook-save-btn:hover{background:#115e59!important;border-color:#115e59!important;}
.btn.primary,.btn.btn-primary{background:#16a34a!important;border-color:#16a34a!important;color:#fff!important;}
.btn.primary:hover,.btn.btn-primary:hover{background:#15803d!important;border-color:#15803d!important;}
.institution-theme-dark .institution-hero{background-color:var(--bg-dark)!important;color:#fff!important;}
.institution-theme-minimal .institution-hero{box-shadow:none!important;border-bottom:1px solid var(--border-light)!important;}
.institution-hero-split.institution-page .institution-hero,.institution-hero-split .institution-hero{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(280px,420px)!important;align-items:center!important;text-align:left!important;}
.institution-hero-compact .institution-hero{padding-block:54px!important;}
.institution-template-visual .institution-hero .hero-search{box-shadow:0 28px 75px rgba(0,0,0,.18)!important;}
/* 2026-05-14: impersonation pill moved to bottom-right (see definition near line 10625) */
@media(max-width:1023px){
  .admin-sidebar-collapse-toggle{display:none!important;}
  .admin-sidebar-close{display:grid!important;place-items:center!important;flex:0 0 auto!important;margin-left:auto!important;}
  .admin-sidebar{background:#092014!important;width:min(86vw,370px)!important;max-width:min(86vw,370px)!important;}
  .admin-sidebar-overlay{background:transparent!important;backdrop-filter:none!important;}
  .admin-sidebar-header{justify-content:space-between!important;}
  .admin-topbar{grid-template-columns:auto auto minmax(0,1fr) auto!important;gap:10px!important;}
  .admin-search{display:none!important;}
  .admin-topbar-actions{gap:8px!important;}
  .admin-profile-menu,.admin-logout-form{display:none!important;}
  .review-actions-cell{min-width:0!important;}
  .review-action-stack{grid-template-columns:1fr!important;min-width:0!important;width:100%!important;}
  .inline-form-grid{grid-template-columns:1fr!important;min-width:0!important;width:100%!important;}
  .admin-table-wrap{border:0!important;background:transparent!important;box-shadow:none!important;}
  .admin-table-wrap table:not(.no-mobile-card),.admin-table-wrap table.admin-table:not(.no-mobile-card){min-width:0!important;width:100%!important;}
  .admin-table-wrap table.admin-table:not(.no-mobile-card) thead{display:none!important;}
  .admin-table-wrap table.admin-table:not(.no-mobile-card) tbody,.admin-table-wrap table.admin-table:not(.no-mobile-card) tr,.admin-table-wrap table.admin-table:not(.no-mobile-card) td{display:block!important;width:100%!important;}
  .admin-table-wrap table.admin-table:not(.no-mobile-card) tr{padding:14px!important;margin-bottom:12px!important;border:1px solid #dbe7df!important;border-radius:var(--inrep-radius, 10px) !important;background:#fff!important;box-shadow:0 10px 26px rgba(15,23,42,.05)!important;}
  .admin-table-wrap table.admin-table:not(.no-mobile-card) td{padding:9px 0!important;border:0!important;border-bottom:1px solid #eef2f7!important;}
  .admin-table-wrap table.admin-table:not(.no-mobile-card) td:last-child{border-bottom:0!important;}
  .table-actions,.inline-actions{width:100%!important;}
  .table-actions .btn,.inline-actions .btn{flex:1 1 auto!important;justify-content:center!important;}
}
@media(max-width:640px){
  .table-bulk-bar{display:grid!important;grid-template-columns:1fr!important;}
  .table-bulk-bar .btn,.table-bulk-bar input,.table-bulk-bar select{width:100%!important;max-width:100%!important;}
}

/* 2026-05-11 dashboard-routing-notify-hotfix: final responsive/table/action polish */
.hero-eyebrow,
.section-eyebrow,
.eyebrow {
  margin-bottom: 18px !important;
}
.hero-eyebrow + .section-title,
.hero-eyebrow + .admin-page-title,
.hero-eyebrow + h1,
.hero-eyebrow + h2,
.section-eyebrow + h1,
.section-eyebrow + h2,
.eyebrow + h1,
.eyebrow + h2,
.eyebrow + .admin-page-title {
  margin-top: 6px !important;
}
.notification-row.is-unread,
.notification-card.is-unread,
.admin-notification.is-unread,
[data-notification-state="unread"] {
  background: #fff7ed !important;
  border-color: #fed7aa !important;
  box-shadow: inset 4px 0 0 #f97316 !important;
}
.status-badge.unread,
.unread-badge,
.notification-unread-badge {
  background: #fffbeb !important;
  color: #92400e !important;
  border: 1px solid #fde68a !important;
  box-shadow: none !important;
}
.admin-table-wrap table,
.admin-table-wrap .admin-table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}
.admin-table-wrap th,
.admin-table-wrap td {
  vertical-align: top !important;
}
.admin-table-wrap td:last-child,
.admin-actions-cell,
.review-actions-cell,
.table-actions-cell {
  white-space: normal !important;
}
.table-actions,
.inline-actions,
.admin-table-actions,
.action-stack,
.review-action-stack,
.admin-actions-cell > div,
.table-actions-cell > div {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
}
.table-actions form,
.inline-actions form,
.admin-table-actions form,
.action-stack form,
.review-action-stack form,
.admin-actions-cell form,
.table-actions-cell form {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin: 0 !important;
}
.table-actions .btn,
.inline-actions .btn,
.admin-table-actions .btn,
.action-stack .btn,
.review-action-stack .btn,
.admin-actions-cell .btn,
.table-actions-cell .btn {
  min-height: 34px !important;
  white-space: nowrap !important;
}
.compact-table td,
.compact-table th,
.library-review-table td,
.library-review-table th {
  padding: 10px 12px !important;
}
.institution-notify-panel .notify-users-form {
  align-items: end !important;
}
.institution-notify-panel textarea {
  min-height: 104px !important;
}
.institution-notify-panel .notify-users-submit {
  min-width: 160px !important;
  justify-content: center !important;
}
a[href*="webhook"].btn,
button[name*="webhook"],
.webhook-test-btn,
.webhook-save-btn,
.webhook-actions .btn,
.webhook-card .btn,
.webhook-url-grid .btn {
  background: #0f766e !important;
  border-color: #0f766e !important;
  color: #fff !important;
  box-shadow: 0 12px 26px rgba(15, 118, 110, .18) !important;
}
.impersonation-floating-stop {
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 2147483000 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 10px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #111827 !important;
  color: #fff !important;
  box-shadow: 0 20px 55px rgba(15,23,42,.25) !important;
}
.impersonation-floating-stop .btn {
  min-height: 34px !important;
  padding: 7px 12px !important;
}
.analytics-chart-card canvas,
.mini-chart {
  width: 100% !important;
  display: block !important;
}
@media (max-width: 1023px) {
  body.admin-sidebar-open { overflow: hidden !important; }
  body.admin-sidebar-collapsed .admin-shell,
  body:not(.admin-sidebar-collapsed) .admin-shell {
    grid-template-columns: minmax(0, 1fr) !important;
  }
  .admin-sidebar {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(88vw, 360px) !important;
    max-width: min(88vw, 360px) !important;
    min-width: 0 !important;
    height: 100dvh !important;
    transform: translateX(-105%) !important;
    transition: transform .22s ease !important;
    z-index: 1200 !important;
    box-shadow: 24px 0 80px rgba(15, 23, 42, .18) !important;
    border-right: 1px solid rgba(255,255,255,.08) !important;
  }
  body.admin-sidebar-open .admin-sidebar {
    transform: translateX(0) !important;
  }
  .admin-sidebar-overlay {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 1190 !important;
    background: rgba(15, 23, 42, .22) !important;
    backdrop-filter: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity .18s ease, visibility .18s ease !important;
  }
  body.admin-sidebar-open .admin-sidebar-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .admin-sidebar-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
  }
  .admin-sidebar-close,
  [data-admin-sidebar-close] {
    margin-left: auto !important;
    width: 44px !important;
    height: 44px !important;
    display: inline-grid !important;
    place-items: center !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .admin-topbar-menu,
  [data-admin-sidebar-toggle] {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    min-width: 46px !important;
    width: 46px !important;
    height: 46px !important;
  }
  .admin-topbar-menu svg,
  [data-admin-sidebar-toggle] svg {
    width: 27px !important;
    height: 27px !important;
    stroke-width: 2.5 !important;
  }
  .admin-topbar {
    grid-template-columns: auto auto minmax(0,1fr) auto !important;
  }
  .review-action-stack,
  .table-actions,
  .inline-actions,
  .admin-table-actions,
  .action-stack {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }
  .review-action-stack form,
  .table-actions form,
  .inline-actions form,
  .admin-table-actions form,
  .action-stack form {
    width: 100% !important;
  }
  .review-action-stack .btn,
  .table-actions .btn,
  .inline-actions .btn,
  .admin-table-actions .btn,
  .action-stack .btn {
    width: 100% !important;
    justify-content: center !important;
  }
}

/* COMPLETE_WORKFLOW_FIX: shared dashboard/table/mobile polish */
.hero-eyebrow,
.eyebrow.hero-eyebrow,
.hero .hero-eyebrow {
  display: inline-flex;
  margin-bottom: .85rem !important;
}

.responsive-table,
.table-responsive,
.admin-table-wrap,
.review-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.responsive-table table,
.table-responsive table,
.admin-table-wrap table,
.review-table-wrap table,
.compact-table {
  width: 100%;
  min-width: 920px;
  border-collapse: separate;
  border-spacing: 0;
}

.compact-table th,
.compact-table td,
.admin-table th,
.admin-table td,
.review-table th,
.review-table td {
  vertical-align: top;
  padding: .75rem .8rem;
}

.table-actions,
.admin-table-actions,
.review-action-stack,
.inline-actions,
.action-stack,
td.actions,
td.action-column {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: .4rem !important;
  align-items: center !important;
  justify-content: flex-end !important;
  min-width: 150px;
}

.table-actions form,
.admin-table-actions form,
.review-action-stack form,
.inline-actions form,
.action-stack form {
  display: inline-flex !important;
  width: auto !important;
  margin: 0 !important;
}

.table-actions .btn,
.admin-table-actions .btn,
.review-action-stack .btn,
.inline-actions .btn,
.action-stack .btn,
td.actions .btn,
td.action-column .btn {
  width: auto !important;
  white-space: nowrap !important;
  justify-content: center !important;
}

.notification-card.unread,
.notification-item.unread,
.unread-notification,
[data-notification-status="unread"] {
  background: linear-gradient(135deg, rgba(29,185,84,.14), rgba(255,255,255,.96)) !important;
  border-color: rgba(29,185,84,.35) !important;
  box-shadow: inset 4px 0 0 rgba(29,185,84,.85) !important;
}

.webhook-action-btn,
button[name="webhook"],
.btn.webhook,
.btn[data-action="webhook"],
a[href*="webhook"].btn {
  background: #111827 !important;
  color: #fff !important;
  border: 1px solid #111827 !important;
  box-shadow: 0 10px 20px rgba(17,24,39,.18) !important;
}

.webhook-action-btn:hover,
.btn.webhook:hover,
.btn[data-action="webhook"]:hover,
a[href*="webhook"].btn:hover {
  background: #030712 !important;
  color: #fff !important;
}

.impersonation-floating-stop {
  position: fixed !important;
  top: 1rem !important;
  right: 1rem !important;
  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  gap: .7rem !important;
  padding: .65rem .8rem !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(17,24,39,.95) !important;
  color: #fff !important;
  box-shadow: 0 18px 44px rgba(15,23,42,.32) !important;
}

.impersonation-floating-stop strong { color: #fff !important; }
.impersonation-floating-stop .btn { min-height: 34px !important; }

.researcher-dashboard .metric-card,
.student-dashboard .metric-card,
.librarian-dashboard .metric-card,
.institution-dashboard .metric-card {
  min-width: 0;
}

@media (max-width: 900px) {
  .admin-sidebar {
    width: min(86vw, 340px) !important;
    max-width: min(86vw, 340px) !important;
    left: 0 !important;
    right: auto !important;
    box-shadow: 24px 0 60px rgba(15,23,42,.24) !important;
  }

  .admin-sidebar-overlay {
    background: rgba(15,23,42,.18) !important;
  }

  body:not(.admin-sidebar-open) .admin-sidebar-overlay {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .admin-sidebar-header {
    justify-content: space-between !important;
    padding-right: .5rem !important;
  }

  .admin-sidebar-close,
  [data-admin-sidebar-close] {
    margin-left: auto !important;
    margin-right: 0 !important;
  }

  .admin-topbar {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto !important;
    align-items: center !important;
    gap: .65rem !important;
  }

  .admin-topbar-brand,
  .admin-logo {
    justify-self: start !important;
    min-width: 0 !important;
  }

  .admin-topbar-menu,
  [data-admin-sidebar-toggle] {
    justify-self: end !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    min-width: 48px !important;
    width: 48px !important;
    height: 48px !important;
    padding: 0 !important;
  }

  .admin-topbar-menu svg,
  [data-admin-sidebar-toggle] svg {
    width: 30px !important;
    height: 30px !important;
    stroke-width: 2.65 !important;
  }

  .table-actions,
  .admin-table-actions,
  .review-action-stack,
  .inline-actions,
  .action-stack,
  td.actions,
  td.action-column {
    justify-content: flex-start !important;
  }

  .table-actions .btn,
  .admin-table-actions .btn,
  .review-action-stack .btn,
  .inline-actions .btn,
  .action-stack .btn {
    flex: 0 0 auto !important;
  }
}

/* INREP NERD/DSpace upgrade: document-type forms, citations and verification */
.doc-type-field[hidden]{display:none!important}
.doc-type-field{border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:var(--inrep-radius, 10px) !important;padding:12px;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.document-type-hint{margin-bottom:10px}
.citation-workbench .citation-style-grid{display:flex;flex-wrap:wrap;gap:.45rem;margin:.75rem 0}
.citation-workbench .citation-box{width:100%;min-height:138px;border:1px solid rgba(15,23,42,.12);border-radius:var(--inrep-radius, 10px) !important;padding:1rem;background:#f8fafc;font:500 .95rem/1.6 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:#0f172a;resize:vertical}
.citation-metadata-note{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;margin:.7rem 0 1rem;color:#475569;font-size:.88rem}
.citation-metadata-note span{background:#eef2ff;border:1px solid rgba(79,70,229,.14);color:#3730a3;border-radius:var(--inrep-radius, 10px) !important;padding:.25rem .55rem}
.verification-page{padding:48px 0}.verification-card{max-width:960px;margin:0 auto}.verification-card .metadata-grid{margin-top:1rem}

/* HOTFIX: separate alternating public feature-showcase sections.
   Some earlier global dark-section overrides forced .section-white/.mkt-light showcases
   to keep the dark background, making adjacent blocks look merged. */
section.feature-showcase.section-white,
section.feature-showcase.mkt-light {
  background: #f7faf7 !important;
  color: var(--text-dark) !important;
  border-top: 1px solid rgba(10, 31, 21, .08) !important;
  border-bottom: 1px solid rgba(10, 31, 21, .08) !important;
}

section.feature-showcase.section-white::before,
section.feature-showcase.section-white::after,
section.feature-showcase.mkt-light::before,
section.feature-showcase.mkt-light::after {
  display: none !important;
  content: none !important;
}

section.feature-showcase.section-white .feature-showcase-grid,
section.feature-showcase.mkt-light .feature-showcase-grid {
  align-items: center !important;
}

section.feature-showcase.section-white h1,
section.feature-showcase.section-white h2,
section.feature-showcase.section-white h3,
section.feature-showcase.section-white .section-title,
section.feature-showcase.section-white .feature-showcase-h2,
section.feature-showcase.mkt-light h1,
section.feature-showcase.mkt-light h2,
section.feature-showcase.mkt-light h3,
section.feature-showcase.mkt-light .section-title,
section.feature-showcase.mkt-light .feature-showcase-h2 {
  color: var(--text-dark) !important;
}

section.feature-showcase.section-white p,
section.feature-showcase.section-white .feature-showcase-desc,
section.feature-showcase.mkt-light p,
section.feature-showcase.mkt-light .feature-showcase-desc {
  color: var(--text-muted-dark) !important;
}

section.feature-showcase.section-white .hero-eyebrow,
section.feature-showcase.mkt-light .hero-eyebrow {
  margin-bottom: 1rem !important;
  background: rgba(29, 185, 84, .08) !important;
  border-color: rgba(29, 185, 84, .24) !important;
  color: var(--primary) !important;
}

section.feature-showcase.section-white .feature-showcase-link,
section.feature-showcase.mkt-light .feature-showcase-link {
  color: var(--primary) !important;
}

section.feature-showcase.section-white .feature-showcase-link:hover,
section.feature-showcase.mkt-light .feature-showcase-link:hover {
  color: var(--text-dark) !important;
}

section.feature-showcase + section.feature-showcase.section-white,
section.feature-showcase + section.feature-showcase.mkt-light {
  margin-top: 0 !important;
}

@media (max-width: 900px) {
  section.feature-showcase.section-white,
  section.feature-showcase.mkt-light {
    padding-top: clamp(64px, 10vw, 86px) !important;
    padding-bottom: clamp(64px, 10vw, 86px) !important;
  }
}

/* HOTFIX: features page storage card - remove inherited dark/decorative overlays and fix bullet spacing. */
section.feature-showcase.section-white .storage-modes-card {
  position: relative !important;
  z-index: 5 !important;
  width: min(520px, 100%) !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: 14px !important;
  padding: clamp(28px, 4vw, 42px) !important;
  background: #fff !important;
  border: 1px solid var(--border-light, #dfe8df) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 24px 70px rgba(10,31,21,.12) !important;
  color: var(--text-dark, #0a1f15) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}

section.feature-showcase.section-white .storage-modes-card::before,
section.feature-showcase.section-white .storage-modes-card::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

section.feature-showcase.section-white .storage-modes-card b {
  display: block !important;
  color: var(--text-dark, #0a1f15) !important;
  font-size: 1.1rem !important;
  line-height: 1.25 !important;
  margin: 0 0 8px !important;
}

section.feature-showcase.section-white .storage-modes-card span {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-height: 52px !important;
  padding: 12px 18px 12px 48px !important;
  border: 1px solid var(--border-light, #dfe8df) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f7faf7 !important;
  color: var(--text-dark, #0a1f15) !important;
  font-weight: 750 !important;
  line-height: 1.25 !important;
  white-space: normal !important;
  overflow: hidden !important;
}

section.feature-showcase.section-white .storage-modes-card span::before {
  content: '' !important;
  position: absolute !important;
  left: 18px !important;
  top: 50% !important;
  width: 16px !important;
  height: 16px !important;
  transform: translateY(-50%) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 2px solid var(--primary, #1db954) !important;
  background: #fff !important;
  box-sizing: border-box !important;
  z-index: 1 !important;
}

section.feature-showcase.section-white .storage-modes-card span::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

/* HOTFIX: features page split sections - avoid old feature-showcase overrides and restore arranged cards. */
.public-body.features-page .inrep-feature-band {
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(84px, 9vw, 128px) 0 !important;
  margin: 0 !important;
}

.public-body.features-page .inrep-feature-band-dark {
  background: #062315 !important;
  color: #fff !important;
}

.public-body.features-page .inrep-feature-band-dark::after {
  content: '' !important;
  position: absolute !important;
  right: -12vw !important;
  bottom: -18vw !important;
  width: 42vw !important;
  height: 42vw !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29, 185, 84, .06) !important;
  pointer-events: none !important;
}

.public-body.features-page .inrep-feature-band-light {
  background: #f7faf7 !important;
  color: #07140d !important;
  border-top: 1px solid rgba(10, 31, 21, .08) !important;
  border-bottom: 1px solid rgba(10, 31, 21, .08) !important;
}

.public-body.features-page .inrep-feature-split {
  width: min(1180px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px) !important;
  gap: clamp(44px, 7vw, 104px) !important;
  align-items: center !important;
  position: relative !important;
  z-index: 2 !important;
}

.public-body.features-page .inrep-feature-copy {
  max-width: 620px !important;
  display: block !important;
}

.public-body.features-page .inrep-feature-copy .hero-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  margin: 0 0 24px !important;
}

.public-body.features-page .inrep-feature-copy h2 {
  margin: 0 !important;
  font-family: var(--font-display, Sora, sans-serif) !important;
  font-size: clamp(2.4rem, 5vw, 4.45rem) !important;
  line-height: .98 !important;
  letter-spacing: -.07em !important;
  color: inherit !important;
}

.public-body.features-page .inrep-feature-copy p {
  margin: 28px 0 0 !important;
  max-width: 640px !important;
  font-size: clamp(1rem, 1.1vw, 1.12rem) !important;
  line-height: 1.7 !important;
  color: rgba(255, 255, 255, .78) !important;
}

.public-body.features-page .inrep-feature-band-light .inrep-feature-copy p {
  color: #607267 !important;
}

.public-body.features-page .inrep-feature-link {
  display: inline-flex !important;
  align-items: center !important;
  margin-top: 24px !important;
  color: #1db954 !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.public-body.features-page .inrep-feature-link:hover {
  color: #0c8f3f !important;
}

.public-body.features-page .inrep-feature-band-dark .inrep-feature-link:hover {
  color: #fff !important;
}

.public-body.features-page .inrep-feature-panel {
  display: grid !important;
  gap: 16px !important;
  padding: clamp(28px, 4vw, 42px) !important;
  background: #fff !important;
  border: 1px solid rgba(10, 31, 21, .12) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .18) !important;
}

.public-body.features-page .inrep-feature-panel span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 56px !important;
  padding: 14px 18px !important;
  border: 1px solid #dfe8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f7faf7 !important;
  color: #07140d !important;
  font-weight: 850 !important;
  text-align: center !important;
  line-height: 1.2 !important;
}

.public-body.features-page .storage-modes-card-clean {
  position: relative !important;
  display: grid !important;
  gap: 18px !important;
  width: min(520px, 100%) !important;
  margin: 0 !important;
  padding: clamp(28px, 4vw, 42px) !important;
  background: #fff !important;
  border: 1px solid #dfe8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 24px 70px rgba(10, 31, 21, .10) !important;
  color: #07140d !important;
  overflow: hidden !important;
}

.public-body.features-page .storage-modes-card-clean::before,
.public-body.features-page .storage-modes-card-clean::after {
  content: none !important;
  display: none !important;
}

.public-body.features-page .storage-modes-card-clean h3 {
  margin: 0 0 4px !important;
  color: #07140d !important;
  font-size: 1.2rem !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
}

.public-body.features-page .storage-modes-card-clean ul {
  display: grid !important;
  gap: 14px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.public-body.features-page .storage-modes-card-clean li {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-height: 58px !important;
  padding: 14px 18px 14px 52px !important;
  border: 1px solid #dfe8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f7faf7 !important;
  color: #07140d !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}

.public-body.features-page .storage-modes-card-clean li::before {
  content: '' !important;
  position: absolute !important;
  left: 20px !important;
  top: 50% !important;
  width: 16px !important;
  height: 16px !important;
  transform: translateY(-50%) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 2px solid #1db954 !important;
  background: #fff !important;
  box-sizing: border-box !important;
}

.public-body.features-page .storage-modes-card-clean li span {
  display: block !important;
  color: inherit !important;
  overflow-wrap: anywhere !important;
}

@media (max-width: 980px) {
  .public-body.features-page .inrep-feature-band {
    padding: 72px 0 !important;
  }

  .public-body.features-page .inrep-feature-split {
    grid-template-columns: 1fr !important;
    gap: 34px !important;
    width: min(100% - 32px, 720px) !important;
  }

  .public-body.features-page .inrep-feature-copy,
  .public-body.features-page .storage-modes-card-clean {
    max-width: none !important;
    width: 100% !important;
  }
}

@media (max-width: 560px) {
  .public-body.features-page .inrep-feature-copy h2 {
    font-size: clamp(2rem, 13vw, 3rem) !important;
  }

  .public-body.features-page .inrep-feature-panel,
  .public-body.features-page .storage-modes-card-clean {
    padding: 22px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
}

/* 2026-05-12: public implementation rollout cards - isolated from generic admin timeline styles */
.rollout-section {
  padding: clamp(72px, 7vw, 112px) 0 !important;
  background: #fff !important;
  color: #071510 !important;
}
.rollout-heading {
  width: min(940px, calc(100% - 48px)) !important;
  margin: 0 auto clamp(34px, 4vw, 54px) !important;
  text-align: center !important;
}
.rollout-heading .hero-eyebrow {
  margin-bottom: 18px !important;
}
.rollout-intro {
  max-width: 720px !important;
  margin: 16px auto 0 !important;
  color: #5b6f65 !important;
  font-size: clamp(16px, 1.5vw, 19px) !important;
  line-height: 1.65 !important;
}
.rollout-steps {
  width: min(1050px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: 18px !important;
}
.rollout-step-card {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 74px minmax(0, 1fr) !important;
  gap: 24px !important;
  align-items: start !important;
  padding: clamp(24px, 3vw, 34px) !important;
  min-height: auto !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(135deg, #ffffff 0%, #f8fbf8 100%) !important;
  box-shadow: 0 20px 60px rgba(10, 31, 21, .06) !important;
  overflow: hidden !important;
}
.rollout-step-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 0 0 auto !important;
  width: 6px !important;
  background: linear-gradient(180deg, #18c768, #0d7c3d) !important;
  opacity: .95 !important;
}
.rollout-step-number {
  width: 56px !important;
  height: 56px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid !important;
  place-items: center !important;
  background: #071510 !important;
  color: #fff !important;
  font-family: var(--font-display, inherit) !important;
  font-size: 17px !important;
  font-weight: 900 !important;
  letter-spacing: .02em !important;
  box-shadow: 0 16px 34px rgba(7, 21, 16, .16) !important;
}
.rollout-step-content h3 {
  margin: 0 0 10px !important;
  color: #071510 !important;
  font-family: var(--font-display, inherit) !important;
  font-size: clamp(22px, 2.2vw, 30px) !important;
  line-height: 1.12 !important;
  letter-spacing: -.035em !important;
}
.rollout-step-content p {
  margin: 0 !important;
  max-width: 780px !important;
  color: #52685d !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}
@media (max-width: 720px) {
  .rollout-section {
    padding: 56px 0 !important;
  }
  .rollout-heading,
  .rollout-steps {
    width: min(100% - 32px, 1050px) !important;
  }
  .rollout-step-card {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    padding: 22px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .rollout-step-card::after {
    width: 100% !important;
    height: 5px !important;
    inset: 0 0 auto 0 !important;
  }
  .rollout-step-number {
    width: 50px !important;
    height: 50px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
}

/* 2026-05-12 repository projects page design repair */
.repository-browser-shell {
  width: 100% !important;
  background: linear-gradient(180deg, #f8fbf8 0%, #f3f8f4 100%) !important;
  border-top: 1px solid #e6efe8 !important;
  border-bottom: 1px solid #e6efe8 !important;
  padding: clamp(42px, 5vw, 72px) 0 clamp(64px, 7vw, 96px) !important;
  margin: 0 !important;
}
.repository-layout-v2.repository-browser-enhanced {
  width: min(1360px, calc(100% - 48px)) !important;
  max-width: 1360px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(250px, 292px) minmax(0, 1fr) !important;
  gap: clamp(24px, 3vw, 38px) !important;
  align-items: start !important;
  background: transparent !important;
}
.repository-layout-v2 .repository-filter-card,
.repository-layout-v2 .repository-facet-sidebar {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 20px !important;
  border: 1px solid #ddeade !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(15, 38, 24, .08) !important;
  position: sticky !important;
  top: 92px !important;
  gap: 14px !important;
}
.repository-layout-v2 .repository-facet-sidebar label {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
  color: #102518 !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}
.repository-layout-v2 .repository-facet-sidebar input[type="text"],
.repository-layout-v2 .repository-facet-sidebar input:not([type]),
.repository-layout-v2 .repository-facet-sidebar select {
  width: 100% !important;
  min-height: 46px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #102518 !important;
  padding: 10px 12px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.repository-layout-v2 .repository-facet-sidebar details {
  width: 100% !important;
  border: 1px solid #e1ebe3 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 12px !important;
  background: #fbfdfb !important;
}
.repository-layout-v2 .repository-facet-sidebar summary {
  list-style: none !important;
  cursor: pointer !important;
  color: #102518 !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.repository-layout-v2 .repository-facet-sidebar summary::-webkit-details-marker { display: none !important; }
.repository-layout-v2 .repository-facet-sidebar summary::before {
  content: "\25B8" !important;
  font-size: 12px !important;
  color: #0f8f3e !important;
  transition: transform .16s ease !important;
}
.repository-layout-v2 .repository-facet-sidebar details[open] summary::before { transform: rotate(90deg) !important; }
.repository-layout-v2 .facet-option-grid {
  display: grid !important;
  gap: 7px !important;
  margin-top: 12px !important;
}
.repository-layout-v2 .facet-option-grid label {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 34px !important;
  padding: 7px 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: #233a2a !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  cursor: pointer !important;
}
.repository-layout-v2 .facet-option-grid label:hover { background: #f1f8f3 !important; }
.repository-layout-v2 .facet-option-grid input[type="radio"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  flex: 0 0 16px !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 2px solid #b8c9bd !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: inset 0 0 0 3px #fff !important;
}
.repository-layout-v2 .facet-option-grid input[type="radio"]:checked {
  border-color: #0f8f3e !important;
  background: #0f8f3e !important;
}
.repository-layout-v2 .filter-actions {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  margin-top: 6px !important;
}
.repository-layout-v2 .filter-actions .btn {
  width: 100% !important;
  justify-content: center !important;
  min-height: 42px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.repository-layout-v2 .repository-results-pane {
  min-width: 0 !important;
  width: 100% !important;
}
.repository-layout-v2 .repository-results-head {
  width: 100% !important;
  margin: 0 0 22px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  color: #66776b !important;
}
.repository-layout-v2 .repository-results-summary {
  display: grid !important;
  gap: 3px !important;
  min-width: 0 !important;
}
.repository-layout-v2 .repository-results-summary strong {
  display: block !important;
  color: #102518 !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
}
.repository-layout-v2 .repository-results-summary span {
  display: block !important;
  color: #66776b !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
.repository-layout-v2 .view-toggle {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.repository-layout-v2 .view-toggle .btn.tiny {
  min-height: 32px !important;
  height: 32px !important;
  padding: 0 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 12px !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid,
.repository-layout-v2 .projects-public-grid {
  width: 100% !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list {
  grid-template-columns: 1fr !important;
}
.repository-layout-v2 .repository-card,
.repository-layout-v2 .project-public-card {
  min-width: 0 !important;
  height: 100% !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding: 22px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #102518 !important;
  box-shadow: 0 12px 34px rgba(15, 38, 24, .055) !important;
  transform: none !important;
  overflow: hidden !important;
}
.repository-layout-v2 .repository-card:hover,
.repository-layout-v2 .project-public-card:hover {
  border-color: #b9dec2 !important;
  box-shadow: 0 18px 44px rgba(15, 38, 24, .085) !important;
  transform: translateY(-2px) !important;
}
.repository-layout-v2 .project-card-top {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin: 0 0 2px !important;
}
.repository-layout-v2 .project-card-top .pill {
  max-width: 72% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  border: 1px solid #dce8df !important;
  background: #f7fbf8 !important;
  color: #586a5e !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  padding: 7px 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.repository-layout-v2 .project-card-top small {
  color: #66776b !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}
.repository-layout-v2 .project-public-card h3 {
  margin: 0 !important;
  color: #0b0f0c !important;
  font-size: clamp(16px, 1.45vw, 19px) !important;
  line-height: 1.22 !important;
  font-weight: 900 !important;
  letter-spacing: -.018em !important;
}
.repository-layout-v2 .project-public-card h3 a {
  color: inherit !important;
  text-decoration: none !important;
}
.repository-layout-v2 .project-public-card h3 a:hover { color: #0f8f3e !important; }
.repository-layout-v2 .project-public-card p {
  margin: 0 !important;
  color: #5d6f63 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 5 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.repository-layout-v2 .project-meta-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  margin-top: auto !important;
  padding-top: 4px !important;
}
.repository-layout-v2 .project-meta-list span {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  border: 1px solid #e2ece4 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
  color: #66776b !important;
  font-size: 11px !important;
  font-weight: 750 !important;
  padding: 6px 9px !important;
}
.repository-layout-v2 .project-card-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
  padding-top: 2px !important;
  margin-top: 0 !important;
}
.repository-layout-v2 .project-card-actions .feature-card-link,
.repository-layout-v2 .project-card-actions .as-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  margin: 0 !important;
  padding: 7px 11px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0f7a38 !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}
.repository-layout-v2 .project-card-actions .feature-card-link:hover,
.repository-layout-v2 .project-card-actions .as-button:hover {
  background: #edf8f0 !important;
  border-color: #bce2c5 !important;
  color: #0b5e2c !important;
  gap: 4px !important;
}
.repository-layout-v2 .repository-grid-list .repository-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  gap: 10px 22px !important;
  height: auto !important;
}
.repository-layout-v2 .repository-grid-list .project-public-card p,
.repository-layout-v2 .repository-grid-list .project-meta-list,
.repository-layout-v2 .repository-grid-list .project-card-actions {
  grid-column: 1 / -1 !important;
}
@media (max-width: 980px) {
  .repository-layout-v2.repository-browser-enhanced {
    width: min(100% - 32px, 760px) !important;
    grid-template-columns: 1fr !important;
  }
  .repository-layout-v2 .repository-filter-card,
  .repository-layout-v2 .repository-facet-sidebar {
    position: static !important;
  }
  .repository-layout-v2 .repository-results-head {
    align-items: flex-start !important;
    flex-direction: column !important;
  }
  .repository-layout-v2 .projects-public-grid.repository-grid,
  .repository-layout-v2 .projects-public-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
  }
}
@media (max-width: 620px) {
  .repository-browser-shell { padding: 32px 0 54px !important; }
  .repository-layout-v2.repository-browser-enhanced { width: calc(100% - 28px) !important; }
  .repository-layout-v2 .projects-public-grid.repository-grid,
  .repository-layout-v2 .projects-public-grid {
    grid-template-columns: 1fr !important;
  }
  .repository-layout-v2 .repository-card,
  .repository-layout-v2 .project-public-card,
  .repository-layout-v2 .repository-filter-card {
    border-radius: var(--inrep-radius, 10px) !important;
    padding: 18px !important;
  }
  .repository-layout-v2 .view-toggle { width: 100% !important; justify-content: space-between !important; }
  .repository-layout-v2 .view-toggle .btn.tiny { flex: 1 !important; }
}

/* Repository filters + grid/list final stabilization */
.repository-layout-v2 .repository-facet-sidebar input,
.repository-layout-v2 .repository-facet-sidebar select {
  width: 100% !important;
  max-width: 100% !important;
}
.repository-layout-v2 .facet-option-grid {
  display: grid !important;
  gap: 8px !important;
}
.repository-layout-v2 .facet-option-grid label {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  align-items: center !important;
  column-gap: 10px !important;
  color: #17251b !important;
  line-height: 1.35 !important;
}
.repository-layout-v2 .view-toggle a.btn.tiny {
  text-decoration: none !important;
  color: #102518 !important;
}
.repository-layout-v2 .view-toggle a.btn.tiny.primary,
.repository-layout-v2 .view-toggle a.btn.tiny[aria-pressed="true"] {
  background: #0f8f3e !important;
  border-color: #0f8f3e !important;
  color: #fff !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 18px !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list .project-public-card {
  display: grid !important;
  grid-template-columns: 180px minmax(0, 1fr) auto !important;
  grid-template-areas:
    "top title actions"
    "top abstract actions"
    "top meta actions" !important;
  align-items: start !important;
  column-gap: 18px !important;
  row-gap: 8px !important;
  min-height: 0 !important;
  height: auto !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list .project-card-top {
  grid-area: top !important;
  display: grid !important;
  justify-content: start !important;
  gap: 8px !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list h3 {
  grid-area: title !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list p {
  grid-area: abstract !important;
  -webkit-line-clamp: 2 !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list .project-meta-list {
  grid-area: meta !important;
  margin-top: 0 !important;
}
.repository-layout-v2 .projects-public-grid.repository-grid-list .project-card-actions {
  grid-area: actions !important;
  min-width: 150px !important;
  justify-content: flex-end !important;
  align-content: flex-start !important;
}
@media (max-width: 900px) {
  .repository-layout-v2 .projects-public-grid.repository-grid-list .project-public-card {
    grid-template-columns: 1fr !important;
    grid-template-areas: "top" "title" "abstract" "meta" "actions" !important;
  }
  .repository-layout-v2 .projects-public-grid.repository-grid-list .project-card-actions {
    min-width: 0 !important;
    justify-content: flex-start !important;
  }
}

/* Projects repository page v3: isolated filter + grid/list rendering */
.repo-page-v3 {
  background: #f6faf7 !important;
  padding: 64px 0 84px !important;
}
.repo-browser-v3 {
  width: min(1280px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: 300px minmax(0, 1fr) !important;
  gap: 34px !important;
  align-items: start !important;
}
.repo-filter-wrap-v3 { min-width: 0 !important; }
.repo-filter-v3 {
  position: sticky !important;
  top: 104px !important;
  display: grid !important;
  gap: 14px !important;
  padding: 22px !important;
  border: 1px solid #dbe8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 20px 55px rgba(20, 44, 27, .08) !important;
}
.repo-field-v3,
.repo-facet-v3 {
  display: grid !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.repo-field-v3 > span,
.repo-facet-v3 summary {
  color: #102518 !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}
.repo-facet-v3 {
  padding: 13px !important;
  border: 1px solid #e2ece5 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}
.repo-facet-v3 summary {
  cursor: pointer !important;
  list-style-position: outside !important;
}
.repo-field-v3 input,
.repo-field-v3 select,
.repo-facet-v3 select,
.repo-filter-v3 input:not([type="radio"]),
.repo-filter-v3 select {
  width: 100% !important;
  min-height: 44px !important;
  padding: 0 13px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #142219 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  outline: none !important;
  box-sizing: border-box !important;
}
.repo-field-v3 input:focus,
.repo-field-v3 select:focus,
.repo-facet-v3 select:focus {
  border-color: #22aa50 !important;
  box-shadow: 0 0 0 4px rgba(34, 170, 80, .12) !important;
}
.repo-radio-list-v3 {
  display: grid !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
.repo-radio-list-v3 label {
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 38px !important;
  padding: 8px 10px !important;
  border: 1px solid #e3eee7 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #17251b !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}
.repo-radio-list-v3 label:hover { background: #f1f8f3 !important; }
.repo-radio-list-v3 input[type="radio"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  margin: 0 !important;
  border: 2px solid #b7cabd !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: inset 0 0 0 3px #fff !important;
}
.repo-radio-list-v3 input[type="radio"]:checked {
  border-color: #0f8f3e !important;
  background: #0f8f3e !important;
}
.repo-filter-actions-v3 {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  padding-top: 2px !important;
}
.repo-filter-actions-v3 .btn {
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}
.repo-results-v3 { min-width: 0 !important; }
.repo-results-head-v3 {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin-bottom: 20px !important;
}
.repo-results-head-v3 strong {
  display: block !important;
  color: #0b0f0c !important;
  font-size: 16px !important;
  font-weight: 950 !important;
  line-height: 1.2 !important;
}
.repo-results-head-v3 span {
  display: block !important;
  margin-top: 4px !important;
  color: #66776b !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
.repo-view-toggle-v3 {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 4px !important;
  border: 1px solid #dbe8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.repo-view-toggle-v3 a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 58px !important;
  min-height: 32px !important;
  padding: 0 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  color: #102518 !important;
  text-decoration: none !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}
.repo-view-toggle-v3 a.is-active,
.repo-view-toggle-v3 a[aria-pressed="true"] {
  background: #0f8f3e !important;
  color: #fff !important;
}
.repo-records-v3 {
  display: grid !important;
  gap: 20px !important;
  min-width: 0 !important;
}
.repo-records-v3--grid {
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)) !important;
}
.repo-records-v3--list {
  grid-template-columns: 1fr !important;
}
.repo-record-v3,
.repo-empty-v3 {
  min-width: 0 !important;
  display: grid !important;
  gap: 13px !important;
  padding: 24px !important;
  border: 1px solid #dce9e1 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #102518 !important;
  box-shadow: 0 16px 42px rgba(15, 38, 24, .07) !important;
  overflow: visible !important;
  box-sizing: border-box !important;
}
.repo-record-v3:hover {
  border-color: #b8dec2 !important;
  box-shadow: 0 22px 52px rgba(15, 38, 24, .105) !important;
  transform: translateY(-1px) !important;
}
.repo-record-top-v3 {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.repo-access-pill-v3,
.repo-doc-pill-v3,
.repo-year-v3 {
  display: inline-flex !important;
  align-items: center !important;
  max-width: 100% !important;
  min-width: 0 !important;
  min-height: 30px !important;
  padding: 6px 11px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf9 !important;
  color: #54685b !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
  box-sizing: border-box !important;
}
.repo-access-pill-v3 { color: #0b7434 !important; background: #eff9f2 !important; border-color: #c9ead1 !important; }
.repo-year-v3 { margin-left: auto !important; color: #607268 !important; }
.repo-record-v3 h3,
.repo-empty-v3 h3 {
  margin: 0 !important;
  color: #0b0f0c !important;
  font-size: clamp(17px, 1.55vw, 21px) !important;
  line-height: 1.22 !important;
  font-weight: 950 !important;
  letter-spacing: -.018em !important;
}
.repo-record-v3 h3 a { color: inherit !important; text-decoration: none !important; }
.repo-record-v3 h3 a:hover { color: #0f8f3e !important; }
.repo-record-v3 p,
.repo-empty-v3 p {
  margin: 0 !important;
  color: #5d6f63 !important;
  font-size: 13px !important;
  line-height: 1.58 !important;
}
.repo-records-v3--grid .repo-record-v3 p {
  display: -webkit-box !important;
  -webkit-line-clamp: 5 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.repo-meta-v3 {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  min-width: 0 !important;
}
.repo-meta-v3 span {
  display: inline-flex !important;
  max-width: 100% !important;
  min-height: 28px !important;
  align-items: center !important;
  padding: 5px 9px !important;
  border: 1px solid #e2ece4 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
  color: #66776b !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.repo-actions-v3 {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
}
.repo-actions-v3 a,
.repo-actions-v3 button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 34px !important;
  margin: 0 !important;
  padding: 7px 12px !important;
  border: 1px solid #dce8df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0f7a38 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}
.repo-actions-v3 a:hover,
.repo-actions-v3 button:hover {
  background: #edf8f0 !important;
  border-color: #bce2c5 !important;
  color: #0b5e2c !important;
}
.repo-records-v3--list .repo-record-v3 {
  grid-template-columns: minmax(0, 1fr) auto !important;
  grid-template-areas:
    "top actions"
    "title actions"
    "abstract actions"
    "meta actions" !important;
  align-items: start !important;
  column-gap: 24px !important;
  row-gap: 10px !important;
}
.repo-records-v3--list .repo-record-top-v3 { grid-area: top !important; }
.repo-records-v3--list .repo-record-v3 h3 { grid-area: title !important; }
.repo-records-v3--list .repo-record-v3 p {
  grid-area: abstract !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.repo-records-v3--list .repo-meta-v3 { grid-area: meta !important; }
.repo-records-v3--list .repo-actions-v3 {
  grid-area: actions !important;
  min-width: 160px !important;
  justify-content: flex-end !important;
  align-content: flex-start !important;
}
.repo-records-v3--list .repo-year-v3 { margin-left: 0 !important; }
@media (max-width: 1040px) {
  .repo-browser-v3 {
    width: min(100% - 36px, 760px) !important;
    grid-template-columns: 1fr !important;
  }
  .repo-filter-v3 { position: static !important; }
  .repo-records-v3--grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important; }
}
@media (max-width: 700px) {
  .repo-page-v3 { padding: 40px 0 64px !important; }
  .repo-browser-v3 { width: calc(100% - 28px) !important; gap: 22px !important; }
  .repo-results-head-v3 { flex-direction: column !important; }
  .repo-view-toggle-v3 { width: 100% !important; }
  .repo-view-toggle-v3 a { flex: 1 !important; }
  .repo-records-v3--grid { grid-template-columns: 1fr !important; }
  .repo-records-v3--list .repo-record-v3 {
    grid-template-columns: 1fr !important;
    grid-template-areas: "top" "title" "abstract" "meta" "actions" !important;
  }
  .repo-records-v3--list .repo-actions-v3 { min-width: 0 !important; justify-content: flex-start !important; }
  .repo-record-v3,
  .repo-empty-v3,
  .repo-filter-v3 { padding: 18px !important; border-radius: var(--inrep-radius, 10px) !important; }
  .repo-year-v3 { margin-left: 0 !important; }
}


/* 2026-05-12: projects repository filter/sidebar final repair */
.public-body .repo-page-v3 {
  background: linear-gradient(180deg, #f8fcf9 0%, #f4faf6 100%) !important;
}
.public-body .repo-browser-v3 {
  width: min(1240px, calc(100% - 48px)) !important;
  grid-template-columns: 318px minmax(0, 1fr) !important;
  gap: 32px !important;
}
.public-body .repo-filter-v3 {
  position: sticky !important;
  top: 96px !important;
  display: block !important;
  padding: 22px !important;
  border: 1px solid rgba(15, 89, 42, .12) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 24px 70px rgba(14, 42, 24, .08) !important;
  overflow: hidden !important;
}
.public-body .repo-filter-v3::before {
  content: "" !important;
  display: block !important;
  height: 4px !important;
  margin: -22px -22px 18px !important;
  background: linear-gradient(90deg, #0f8f3e, #2fd66f) !important;
}
.public-body .repo-field-v3,
.public-body .repo-facet-v3 {
  margin: 0 0 16px !important;
}
.public-body .repo-field-search-v3 > span {
  display: block !important;
  margin-bottom: 10px !important;
  color: #07140c !important;
  font-size: 14px !important;
  font-weight: 950 !important;
  letter-spacing: -.01em !important;
}
.public-body .repo-field-search-v3 input {
  height: 48px !important;
  padding: 0 14px 0 42px !important;
  border-color: #dde9e1 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m21 21-4.35-4.35M10.5 18a7.5 7.5 0 1 1 0-15 7.5 7.5 0 0 1 0 15Z' stroke='%2367796d' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat 14px 50% !important;
}
.public-body .repo-facet-v3 {
  padding: 0 !important;
  border: 0 !important;
  border-top: 1px solid #e4eee7 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: transparent !important;
}
.public-body .repo-facet-v3 summary {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 42px !important;
  padding: 0 !important;
  color: #0f2418 !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  line-height: 1.2 !important;
  list-style: none !important;
}
.public-body .repo-facet-v3 summary::-webkit-details-marker { display: none !important; }
.public-body .repo-facet-v3 summary::after {
  content: "\2304" !important;
  color: #52685b !important;
  font-size: 14px !important;
  transform: rotate(-90deg) !important;
  transition: transform .16s ease !important;
}
.public-body .repo-facet-v3[open] summary::after { transform: rotate(0deg) !important; }
.public-body .repo-facet-v3 select,
.public-body .repo-field-v3 select,
.public-body .repo-field-v3 input:not([type="radio"]) {
  height: 46px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #dce9e1 !important;
  background-color: #fff !important;
  color: #132219 !important;
  font-size: 13px !important;
  font-weight: 750 !important;
}
.public-body .repo-radio-list-v3 {
  display: grid !important;
  gap: 10px !important;
  margin: 6px 0 4px !important;
}
.public-body .repo-radio-option-v3,
.public-body .repo-radio-list-v3 label {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  min-height: 44px !important;
  gap: 12px !important;
  padding: 10px 12px !important;
  border: 1px solid #e1ece5 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #142219 !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}
.public-body .repo-radio-option-v3:hover { background: #f5fbf7 !important; border-color: #cde7d5 !important; }
.public-body .repo-radio-control-v3 {
  position: relative !important;
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.public-body .repo-radio-control-v3 input[type="radio"] {
  position: absolute !important;
  inset: 0 !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 2 !important;
}
.public-body .repo-radio-dot-v3 {
  width: 18px !important;
  height: 18px !important;
  border: 1.8px solid #c1d3c8 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: inset 0 0 0 4px #fff !important;
  box-sizing: border-box !important;
}
.public-body .repo-radio-control-v3 input[type="radio"]:checked + .repo-radio-dot-v3 {
  border-color: #16a34a !important;
  background: #16a34a !important;
}
.public-body .repo-radio-label-v3 {
  display: block !important;
  min-width: 0 !important;
  color: #142219 !important;
  white-space: normal !important;
}
.public-body .repo-field-v3 > span:not(:first-child),
.public-body .repo-field-v3 > span:first-child:not(.repo-radio-label-v3) {
  display: block !important;
  margin-bottom: 8px !important;
  color: #17251b !important;
  font-size: 13px !important;
  font-weight: 950 !important;
}
.public-body .repo-filter-actions-v3 {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 104px !important;
  gap: 10px !important;
  padding-top: 4px !important;
  margin-top: 4px !important;
}
.public-body .repo-filter-actions-v3 .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 46px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 13px !important;
  font-weight: 950 !important;
}
.public-body .repo-filter-actions-v3 .btn.primary {
  background: #16a34a !important;
  border-color: #16a34a !important;
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(22, 163, 74, .18) !important;
}
.public-body .repo-filter-actions-v3 a.btn {
  background: #fff !important;
  border: 1px solid #dfe9e2 !important;
  color: #142219 !important;
}
.public-body .repo-results-head-v3 {
  align-items: center !important;
  margin-bottom: 18px !important;
}
.public-body .repo-results-head-v3 strong { font-size: 17px !important; }
.public-body .repo-results-head-v3 span { margin-top: 5px !important; }
.public-body .repo-view-toggle-v3 {
  box-shadow: 0 10px 25px rgba(20, 44, 27, .06) !important;
}
@media (min-width: 1041px) {
  .public-body .repo-records-v3--grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 1040px) {
  .public-body .repo-browser-v3 {
    width: min(760px, calc(100% - 36px)) !important;
    grid-template-columns: 1fr !important;
  }
  .public-body .repo-filter-v3 { position: static !important; }
}
@media (max-width: 560px) {
  .public-body .repo-filter-actions-v3 { grid-template-columns: 1fr !important; }
  .public-body .repo-filter-v3 { padding: 18px !important; border-radius: var(--inrep-radius, 10px) !important; }
  .public-body .repo-filter-v3::before { margin: -18px -18px 16px !important; }
}

/* 2026-05-12: dashboard mobile nav cleanup */
@media (max-width: 1023px) {
  body.admin-fullscreen:not(.admin-sidebar-open) .admin-sidebar {
    transform: translateX(calc(-100% - 32px)) !important;
    visibility: hidden !important;
    pointer-events: none !important;
    box-shadow: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar {
    transform: translateX(0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
    box-shadow: 18px 0 46px rgba(15, 23, 42, .18) !important;
  }

  body.admin-fullscreen:not(.admin-sidebar-open) .admin-sidebar-overlay,
  body.admin-fullscreen:not(.admin-sidebar-open) [data-admin-sidebar-overlay] {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    background: transparent !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-overlay,
  body.admin-fullscreen.admin-sidebar-open [data-admin-sidebar-overlay] {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    background: rgba(15, 23, 42, .18) !important;
  }

  body.admin-fullscreen .admin-topbar {
    display: grid !important;
    grid-template-columns: 44px 38px minmax(0, 1fr) 44px !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 64px !important;
    height: 64px !important;
    padding: 8px 12px !important;
  }

  body.admin-fullscreen .admin-topbar-menu,
  body.admin-fullscreen [data-admin-sidebar-toggle] {
    grid-column: 1 !important;
    justify-self: start !important;
    width: 44px !important;
    min-width: 44px !important;
    height: 44px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  body.admin-fullscreen .admin-topbar .mkt-nav-logo {
    grid-column: 2 !important;
    display: inline-flex !important;
    justify-self: start !important;
    align-items: center !important;
    width: 38px !important;
    min-width: 38px !important;
    margin: 0 !important;
  }

  body.admin-fullscreen .admin-topbar .mkt-nav-logo .inrep-mark {
    width: 34px !important;
    height: 34px !important;
  }

  body.admin-fullscreen .admin-topbar-title {
    grid-column: 3 !important;
    justify-self: start !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-align: left !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 14px !important;
  }

  body.admin-fullscreen .admin-mobile-search-btn {
    grid-column: 4 !important;
    display: inline-grid !important;
    justify-self: end !important;
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
    margin: 0 !important;
  }

  body.admin-fullscreen .admin-search,
  body.admin-fullscreen .admin-topbar-actions {
    display: none !important;
  }
}

@media (max-width: 380px) {
  body.admin-fullscreen .admin-topbar {
    grid-template-columns: 40px 34px minmax(0, 1fr) 40px !important;
    gap: 8px !important;
    padding-inline: 10px !important;
  }

  body.admin-fullscreen .admin-topbar-title {
    font-size: 13px !important;
  }
}

/* 2026-05-12: dashboard mobile full nav and bottom actions */
.admin-sidebar-mobile-footer,
.admin-mobile-action-bar {
  display: none;
}

.admin-sidebar-mobile-footer form,
.admin-mobile-action-form {
  margin: 0;
}

@media (max-width: 1023px) {
  body.admin-fullscreen .admin-main {
    padding-bottom: calc(96px + env(safe-area-inset-bottom)) !important;
  }

  body.admin-fullscreen .admin-sidebar {
    display: flex !important;
    flex-direction: column !important;
    padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section:not(.is-collapsed) .admin-sidebar-links,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section:not(.is-collapsed) [data-sidebar-links] {
    display: grid !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-links,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed [data-sidebar-links] {
    display: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-chevron,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-label span[aria-hidden="true"] {
    transform: rotate(-90deg) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link {
    width: 100% !important;
    min-height: 42px !important;
    height: auto !important;
    justify-content: flex-start !important;
    padding: 10px 12px !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link span {
    display: inline !important;
  }

  body.admin-fullscreen .admin-sidebar-mobile-footer {
    display: grid !important;
    gap: 10px !important;
    margin-top: auto !important;
    padding: 14px 8px 0 !important;
    border-top: 1px solid rgba(255, 255, 255, .10) !important;
  }

  .admin-sidebar-mobile-profile {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    padding: 10px !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: rgba(255,255,255,.07) !important;
    color: #fff !important;
    text-decoration: none !important;
  }

  .admin-sidebar-mobile-profile span:last-child {
    display: grid !important;
    min-width: 0 !important;
  }

  .admin-sidebar-mobile-profile strong,
  .admin-sidebar-mobile-profile small {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .admin-sidebar-mobile-profile strong {
    color: #fff !important;
    font-size: 13px !important;
  }

  .admin-sidebar-mobile-profile small {
    color: rgba(255,255,255,.64) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
  }

  .admin-sidebar-mobile-footer-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  .admin-sidebar-mobile-action {
    min-height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    border: 1px solid rgba(255,255,255,.13) !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: rgba(255,255,255,.08) !important;
    color: #fff !important;
    font: inherit !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
    cursor: pointer !important;
  }

  .admin-sidebar-mobile-action svg {
    width: 16px !important;
    height: 16px !important;
  }

  .admin-sidebar-mobile-action.danger {
    color: #fecaca !important;
    border-color: rgba(248,113,113,.28) !important;
    background: rgba(127,29,29,.22) !important;
  }

  body.admin-fullscreen .admin-mobile-action-bar {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1180 !important;
    display: flex !important;
    align-items: stretch !important;
    gap: 4px !important;
    min-height: calc(68px + env(safe-area-inset-bottom)) !important;
    padding: 7px 8px calc(7px + env(safe-area-inset-bottom)) !important;
    overflow-x: auto !important;
    overscroll-behavior-x: contain !important;
    background: rgba(255,255,255,.98) !important;
    border-top: 1px solid #dfe8e2 !important;
    box-shadow: 0 -14px 36px rgba(15,23,42,.12) !important;
    transition: opacity .16s ease, visibility .16s ease, transform .16s ease !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-mobile-action-bar {
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(100%) !important;
    pointer-events: none !important;
  }

  .admin-mobile-action {
    position: relative !important;
    flex: 0 0 70px !important;
    min-width: 70px !important;
    min-height: 54px !important;
    display: grid !important;
    grid-template-rows: 22px 1fr !important;
    place-items: center !important;
    gap: 2px !important;
    padding: 7px 6px !important;
    border: 0 !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: transparent !important;
    color: #334155 !important;
    font: inherit !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1.1 !important;
    text-align: center !important;
    text-decoration: none !important;
    cursor: pointer !important;
  }

  .admin-mobile-action svg {
    width: 19px !important;
    height: 19px !important;
  }

  .admin-mobile-action span:not(.admin-count-badge) {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .admin-mobile-action:hover,
  .admin-mobile-action:focus-visible {
    background: #eef8f0 !important;
    color: #0f6b3a !important;
    outline: none !important;
  }

  .admin-mobile-action.danger {
    color: #b42318 !important;
  }

  .admin-mobile-action-form {
    flex: 0 0 auto !important;
    display: flex !important;
  }

  .admin-mobile-action .admin-count-badge {
    top: 3px !important;
    right: 14px !important;
  }
}

@media (max-width: 380px) {
  .admin-mobile-action {
    flex-basis: 64px !important;
    min-width: 64px !important;
    font-size: 9px !important;
  }
}

/* 2026-05-12: production stable dashboard chrome */
body.admin-fullscreen {
  background: #f7faf8 !important;
  overflow-x: hidden !important;
}

body.admin-fullscreen .admin-shell,
body.admin-fullscreen .admin-main {
  background: #f7faf8 !important;
}

body.admin-fullscreen .admin-main {
  position: relative !important;
  z-index: 1 !important;
  box-shadow: none !important;
  min-width: 0 !important;
}

body.admin-fullscreen .admin-main::before,
body.admin-fullscreen .admin-main::after,
body.admin-fullscreen .admin-page::before,
body.admin-fullscreen .admin-page::after {
  display: none !important;
  content: none !important;
}

body.admin-fullscreen .admin-topbar {
  position: sticky !important;
  top: 0 !important;
  z-index: 900 !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  min-width: 0 !important;
  background: rgba(255,255,255,.96) !important;
  border-bottom: 1px solid #dfe8e2 !important;
  box-shadow: 0 8px 24px rgba(15,23,42,.06) !important;
  backdrop-filter: blur(12px) !important;
}

body.admin-fullscreen .admin-topbar-title {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

body.admin-fullscreen .admin-topbar-actions {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  min-width: 0 !important;
}

@media (max-width: 1023px) {
  body.admin-fullscreen .admin-shell,
  body.admin-fullscreen .admin-main,
  body.admin-fullscreen .admin-page {
    background: #f7faf8 !important;
  }

  body.admin-fullscreen .admin-main {
    isolation: isolate !important;
  }

  body.admin-fullscreen .admin-sidebar {
    z-index: 1100 !important;
    background: var(--admin-sidebar-bg) !important;
    box-shadow: 22px 0 44px rgba(15,23,42,.16) !important;
  }

  body.admin-fullscreen .admin-sidebar-overlay {
    z-index: 1050 !important;
    background: rgba(15,23,42,.45) !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }

  body.admin-fullscreen:not(.admin-sidebar-open) .admin-sidebar-overlay {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  body.admin-fullscreen .admin-topbar {
    display: grid !important;
    grid-template-columns: 42px 38px minmax(0, 1fr) 42px !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 58px !important;
    padding: 8px 12px !important;
  }

  body.admin-fullscreen .admin-topbar-title {
    grid-column: 3 !important;
    justify-self: center !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  body.admin-fullscreen .admin-topbar-actions {
    grid-column: 4 !important;
    justify-self: end !important;
  }
}

/* 2026-05-12: mobile dashboard drawer desktop-color parity and collapse fix */
@media (max-width: 1023px) {
  body.admin-fullscreen .admin-sidebar {
    background: var(--admin-sidebar-bg) !important;
    color: #ffffff !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar {
    background: var(--admin-sidebar-bg) !important;
    color: #ffffff !important;
    border-right: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: 22px 0 48px rgba(2,8,23,.34) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-header {
    margin: 10px 10px 8px !important;
    padding: 10px 12px !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: var(--admin-sidebar-bg) !important;
    color: #ffffff !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    box-shadow: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-brand,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-brand span,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-header svg {
    color: #ffffff !important;
    opacity: 1 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-close,
  body.admin-fullscreen.admin-sidebar-open [data-admin-sidebar-close] {
    background: rgba(255,255,255,.10) !important;
    border: 1px solid rgba(255,255,255,.18) !important;
    color: #ffffff !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section {
    border-bottom: 1px solid rgba(255,255,255,.07) !important;
    padding: 4px 10px 10px !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-label {
    color: rgba(255,255,255,.58) !important;
    background: transparent !important;
    opacity: 1 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-label-text,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-chevron {
    color: inherit !important;
    opacity: 1 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section:not(.is-collapsed) .admin-sidebar-links,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section:not(.is-collapsed) [data-sidebar-links] {
    display: grid !important;
    gap: 6px !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-links,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed [data-sidebar-links] {
    display: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-chevron,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-section.is-collapsed .admin-sidebar-label span[aria-hidden="true"] {
    transform: rotate(-90deg) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link,
  body.admin-fullscreen.admin-sidebar-open.admin-sidebar-collapsed .admin-sidebar-link {
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 12px !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: transparent !important;
    color: rgba(255,255,255,.84) !important;
    opacity: 1 !important;
    box-shadow: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link span {
    display: inline !important;
    color: inherit !important;
    opacity: 1 !important;
    font-weight: 750 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link svg {
    color: rgba(74,222,128,.88) !important;
    opacity: 1 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link:hover,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link:focus-visible {
    background: rgba(255,255,255,.08) !important;
    color: #ffffff !important;
    outline: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link.active,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link[aria-current="page"] {
    background: rgba(29,185,84,.18) !important;
    color: #ffffff !important;
    box-shadow: inset 3px 0 0 var(--accent-green) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link.active svg,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-link[aria-current="page"] svg {
    color: var(--accent-green) !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-pin {
    color: rgba(255,255,255,.48) !important;
    opacity: .7 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-footer {
    background: var(--admin-sidebar-bg) !important;
    border-top: 1px solid rgba(255,255,255,.10) !important;
    color: #ffffff !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-profile,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-profile strong,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-profile small,
  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-action {
    color: #ffffff !important;
    opacity: 1 !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-mobile-action.danger {
    color: #fecaca !important;
  }
}

/* ===============================================================
   INREP SCHOLAR - UI UPGRADE SYSTEM  (2026-05-13)
   Design tokens - Dark mode - Skeletons - Micro-interactions
   Toast polish - Empty states - Table - Sidebar - Palette
   =============================================================== */

/* -- A1: Extended design tokens -- */
:root {
  /* Colour palette additions */
  --color-info:        #0ea5e9;
  --color-info-soft:   #e0f2fe;
  --color-info-border: #7dd3fc;
  --color-amber:       #f59e0b;
  --color-amber-soft:  #fef3c7;
  --color-amber-border:#fcd34d;
  --color-purple:      #8b5cf6;
  --color-purple-soft: #ede9fe;
  --color-purple-border:#c4b5fd;
  --color-teal:        #14b8a6;
  --color-teal-soft:   #ccfbf1;
  --color-teal-border: #99f6e4;

  /* Spacing scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;

  /* Font-size scale */
  --text-xs:   11px;
  --text-sm:   13px;
  --text-base: 14px;
  --text-md:   16px;
  --text-lg:   18px;
  --text-xl:   20px;
  --text-2xl:  24px;
  --text-3xl:  32px;

  /* Transition speeds */
  --t-fast:   0.12s ease;
  --t-base:   0.20s ease;
  --t-slow:   0.35s ease;

  /* Focus ring */
  --focus-ring: 0 0 0 3px rgba(29,185,84,.30);
  --focus-ring-offset: 0 0 0 1.5px #fff, 0 0 0 4px rgba(29,185,84,.30);
}

/* -- Universal focus visible ring -- */
:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring-offset);
}

/* -- A5: Skeleton screens -- */
@keyframes ir-shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
.skeleton {
  display: block;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(90deg, #e8eee9 25%, #f2f6f2 50%, #e8eee9 75%);
  background-size: 600px 100%;
  animation: ir-shimmer 1.4s ease-in-out infinite;
}
.skeleton-text { height: 14px; margin-bottom: 8px; border-radius: var(--inrep-radius, 10px) !important; }
.skeleton-text.w-3\/4 { width: 75%; }
.skeleton-text.w-1\/2 { width: 50%; }
.skeleton-text.w-full { width: 100%; }
.skeleton-avatar { width: 40px; height: 40px; border-radius: var(--inrep-radius, 10px) !important; flex-shrink: 0; }
.skeleton-badge { height: 22px; width: 70px; border-radius: var(--inrep-radius, 10px) !important; }
.skeleton-btn  { height: 36px; width: 100px; border-radius: var(--inrep-radius, 10px) !important; }
.skeleton-card {
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.skeleton-table-row { display: flex; gap: 12px; padding: 13px 14px; border-bottom: 1px solid var(--border-light); align-items: center; }
.skeleton-table-row .skeleton-text { margin: 0; }

/* Page-level top loading bar */
#ir-page-loader {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  width: 0%;
  background: var(--primary);
  z-index: 99999;
  transition: width .25s ease, opacity .4s ease;
  border-radius: var(--inrep-radius, 10px) !important;
}
#ir-page-loader.is-running { width: 85%; }
#ir-page-loader.is-done    { width: 100%; opacity: 0; }

/* -- A6: Micro-interactions -- */
@keyframes ir-fade-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes ir-scale-in {
  from { opacity: 0; transform: scale(.95); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes ir-shake {
  0%, 100% { transform: translateX(0); }
  15%  { transform: translateX(-6px); }
  30%  { transform: translateX(6px); }
  45%  { transform: translateX(-4px); }
  60%  { transform: translateX(4px); }
  75%  { transform: translateX(-2px); }
  90%  { transform: translateX(2px); }
}
@keyframes ir-bounce-in {
  0%   { transform: scale(0.8); opacity: 0; }
  60%  { transform: scale(1.05); opacity: 1; }
  80%  { transform: scale(0.97); }
  100% { transform: scale(1); }
}
@keyframes ir-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-12px); }
}
@keyframes ir-pulse-ring {
  0%   { box-shadow: 0 0 0 0   rgba(29,185,84,.4); }
  70%  { box-shadow: 0 0 0 10px rgba(29,185,84,0); }
  100% { box-shadow: 0 0 0 0   rgba(29,185,84,0); }
}
@keyframes ir-count-up {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes ir-toast-in {
  from { opacity: 0; transform: translateX(32px) scale(.95); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes ir-toast-out {
  to   { opacity: 0; transform: translateX(32px) scale(.95); height: 0; padding: 0; margin: 0; overflow: hidden; }
}
@keyframes ir-spinner {
  to { transform: rotate(360deg); }
}
/* Teal status badge variant (uses --color-teal tokens) */
.status-badge.teal, .badge-teal {
  background: var(--color-teal-soft);
  color: #0f766e;
  border-color: var(--color-teal-border);
}

/* Card hover lift */
.card,
.admin-panel,
.admin-card,
.dash-card,
.metric-card,
.feature-card,
.pricing-card {
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.card:hover,
.admin-panel:hover,
.feature-card:hover,
.pricing-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(10,31,21,.13);
}
/* Keep interactive-intent cards stable - only lift non-form cards.
   :has() is CSS Level 4; wrap in @supports for older browser safety.
   JS also adds .has-form / .has-table classes as a fallback. */
@supports selector(:has(*)) {
  .admin-panel:has(form):hover,
  .admin-panel:has(table):hover,
  .admin-panel:has(.admin-table-wrap):hover { transform: none; box-shadow: var(--shadow); }
}
/* JS fallback classes for browsers without :has() */
.admin-panel.has-form:hover,
.admin-panel.has-table:hover { transform: none; box-shadow: var(--shadow); }

/* Button press scale */
.btn:active,
button.btn:active,
a.btn:active { transform: scale(.97); }

/* Form field error shake */
.field-error,
input.is-invalid,
select.is-invalid,
textarea.is-invalid {
  animation: ir-shake .4s ease;
  border-color: var(--danger) !important;
  box-shadow: 0 0 0 3px rgba(207,34,46,.18) !important;
}
.field-error-msg {
  color: var(--danger);
  font-size: var(--text-sm);
  margin: 4px 0 0;
  display: flex;
  align-items: center;
  gap: 5px;
}
.field-error-msg::before {
  content: "\26A0";
  font-size: 10px;
}

/* Inline field-level success */
input.is-valid,
select.is-valid,
textarea.is-valid {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(29,185,84,.15) !important;
}

/* Modal/dialog entrance */
.modal,
.admin-modal,
[role="dialog"]:not(.admin-tour-card):not(.shortcut-card) {
  animation: ir-scale-in .22s ease-out both;
}

/* Page content fade-in */
.admin-main > *,
.admin-page-header,
.admin-panel {
  animation: ir-fade-up .22s ease both;
}
/* Stagger panels */
.admin-panel:nth-child(2) { animation-delay: .04s; }
.admin-panel:nth-child(3) { animation-delay: .08s; }
.admin-panel:nth-child(4) { animation-delay: .12s; }

/* Respect user motion preference */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  #ir-page-loader { display: none; }
}

/* -- B3: Toast notification polish -- */
/* Override original top-right positioning to bottom-right */
.admin-toast-stack {
  top: auto !important;
  bottom: 24px !important;
  right: 20px !important;
}
@media (max-width: 720px) {
  /* On mobile keep toasts at top - away from OS navigation gestures */
  .admin-toast-stack {
    top: 10px !important;
    bottom: auto !important;
    right: 10px !important;
    left: 10px !important;
    width: auto !important;
  }
}

/* Entrance animation only - exit is handled by JS via is-exiting class */
.admin-toast {
  animation: ir-toast-in .22s cubic-bezier(.34,1.56,.64,1) both;
  position: relative;
  overflow: hidden;
}
/* Exit animation plays when JS adds .is-exiting */
.admin-toast.is-exiting {
  animation: ir-toast-out .22s ease forwards;
  pointer-events: none;
}

/* Progress bar - drains via CSS animation over 4 s (matches toast timeout) */
@keyframes ir-progress-drain {
  from { width: 100%; }
  to   { width: 0%; }
}
.admin-toast-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 3px;
  background: currentColor;
  opacity: .3;
  border-radius: var(--inrep-radius, 10px) !important;
  animation: ir-progress-drain 4s linear forwards;
}

/* Icon prefix per type */
.admin-toast::before {
  font-size: 15px;
  flex-shrink: 0;
  line-height: 1;
  margin-top: 1px;
}
.admin-toast.success::before { content: "\2713"; }
.admin-toast.error::before   { content: "\2715"; }
.admin-toast.warning::before { content: "\26A0"; }
.admin-toast.info::before    { content: "\2139"; }

/* -- A3: Table modernisation -- */
.admin-table-wrap {
  position: relative;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
/* Fade shadow on right edge when table overflows */
.admin-table-wrap::after {
  content: '';
  position: sticky;
  right: 0;
  top: 0;
  display: block;
  width: 40px;
  height: 100%;
  pointer-events: none;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.9));
  flex-shrink: 0;
}
/* Sticky header row */
.admin-table thead th,
.admin-table > thead > tr > th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--bg-light);
  box-shadow: inset 0 -1px 0 var(--border-light);
}
/* Sort state arrows on th */
.admin-table th[data-sort-dir],
th.sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
.admin-table th[data-sort-dir]::after,
th.sortable::after {
  content: ' \2194';
  opacity: .35;
  font-size: 10px;
}
.admin-table th[data-sort-dir="asc"]::after  { content: ' \2191'; opacity: .8; }
.admin-table th[data-sort-dir="desc"]::after { content: ' \2193'; opacity: .8; }
/* Zebra stripe option */
.admin-table.table--striped tbody tr:nth-child(even) td { background: #fafcfa; }
/* Row hover */
.admin-table tbody tr { transition: background var(--t-fast); }
.admin-table tbody tr:hover td { background: #f4faf5; }
/* Inline row actions - show on hover */
.admin-table tbody tr .row-actions { opacity: 0; transition: opacity var(--t-fast); }
.admin-table tbody tr:hover .row-actions { opacity: 1; }

/* -- B4: Contextual empty states -- */
.ir-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 56px 32px;
  gap: 14px;
}
.ir-empty-state__icon {
  width: 80px;
  height: 80px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--bg-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  margin-bottom: 4px;
}
.ir-empty-state__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text-dark);
  margin: 0;
}
.ir-empty-state__desc {
  color: var(--text-muted-dark);
  font-size: var(--text-base);
  max-width: 360px;
  line-height: 1.6;
  margin: 0;
}
/* Use inside admin-panel tables - replace bare "No data" rows */
.admin-table .ir-empty-state { padding: 40px 24px; }

/* -- A8: Sidebar navigation polish -- */

/* Notification count badge on sidebar links */
.admin-sidebar-link .sidebar-badge {
  margin-left: auto;
  min-width: 20px;
  height: 20px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--danger);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  flex-shrink: 0;
  transition: opacity var(--t-fast);
}
.admin-sidebar-link .sidebar-badge[data-count="0"] { display: none; }

/* Full-width pill highlight for active link */
.admin-sidebar-link.active,
.admin-sidebar-link[aria-current="page"] {
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29,185,84,.16) !important;
}

/* Collapse chevron rotation */
[data-sidebar-section-toggle] .chevron-icon {
  transition: transform var(--t-base);
}
[data-sidebar-section].is-collapsed [data-sidebar-section-toggle] .chevron-icon {
  transform: rotate(-90deg);
}

/* Tooltip on icon-only collapsed sidebar */
body.admin-sidebar-collapsed .admin-sidebar-link {
  position: relative;
}
body.admin-sidebar-collapsed .admin-sidebar-link::after {
  content: attr(data-nav-label);
  position: absolute;
  left: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--bg-dark);
  color: var(--text-light);
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  padding: 5px 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--t-fast);
  z-index: 100;
}
body.admin-sidebar-collapsed .admin-sidebar-link:hover::after { opacity: 1; }

/* -- B2: Command palette upgrade -- */
.suggest-box {
  position: fixed;
  z-index: 9998;
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  animation: ir-scale-in .16s ease both;
  max-height: 420px;
  overflow-y: auto;
  padding: 6px;
}
.suggest-box .suggest-group-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted-dark);
  padding: 8px 12px 4px;
}
.suggest-box .suggest-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: var(--inrep-radius, 10px) !important;
  color: var(--text-dark);
  font-weight: 600;
  font-size: var(--text-base);
  cursor: pointer;
  transition: background var(--t-fast);
  text-decoration: none;
}
.suggest-box .suggest-item:hover,
.suggest-box .suggest-item.is-focused {
  background: var(--bg-light);
  color: var(--primary-dark);
}
.suggest-box .suggest-item small {
  color: var(--text-muted-dark);
  font-weight: 400;
  font-size: 12px;
}
.suggest-box .suggest-item .suggest-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
}
/* Matched keyword highlight */
.suggest-box .suggest-item mark {
  background: var(--primary-soft);
  color: var(--primary-dark);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 0 2px;
  font-style: normal;
}

/* -- A9: Public hero animations -- */
.hero-bg-orb {
  position: absolute;
  border-radius: var(--inrep-radius, 10px) !important;
  filter: blur(80px);
  pointer-events: none;
  animation: ir-float 7s ease-in-out infinite;
}
.hero-bg-orb:nth-child(2) { animation-duration: 9s; animation-delay: -3s; }
.hero-bg-orb:nth-child(3) { animation-duration: 11s; animation-delay: -6s; }

/* Animated stat counter */
.stat-number[data-count-target],
.stat-value[data-count-target] {
  animation: ir-count-up .5s ease both;
}

/* Feature card icon hover bounce */
.feature-card .feature-icon {
  transition: transform var(--t-base);
}
.feature-card:hover .feature-icon {
  transform: translateY(-4px) rotate(-3deg);
}

/* Pricing "Most popular" highlight */
.pricing-card.is-featured {
  border: 2px solid var(--primary);
  transform: scale(1.03);
  box-shadow: 0 20px 48px rgba(29,185,84,.18);
  position: relative;
  z-index: 1;
}
.pricing-card.is-featured:hover {
  transform: scale(1.05) translateY(-3px);
}

/* -- A4: Form improvements -- */
/* Character counter */
.char-counter {
  font-size: var(--text-xs);
  color: var(--text-muted-dark);
  text-align: right;
  margin-top: 3px;
  transition: color var(--t-fast);
}
.char-counter.is-warning { color: var(--color-amber); }
.char-counter.is-over    { color: var(--danger); font-weight: 700; }

/* Input with icon prefix/suffix */
.input-group {
  position: relative;
  display: flex;
  align-items: center;
}
.input-group input {
  padding-left: 40px;
}
.input-group input.has-suffix {
  padding-right: 40px;
}
.input-group-prefix,
.input-group-suffix {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted-dark);
  pointer-events: none;
  display: flex;
  align-items: center;
}
.input-group-prefix { left: 13px; }
.input-group-suffix { right: 13px; }

/* Custom toggle switch */
.toggle-switch {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.toggle-switch input[type="checkbox"] {
  display: none;
}
.toggle-track {
  width: 40px;
  height: 22px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--border-light);
  border: 1px solid var(--border-light);
  position: relative;
  transition: background var(--t-base), border-color var(--t-base);
  flex-shrink: 0;
}
.toggle-thumb {
  position: absolute;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
  transition: left var(--t-base);
}
.toggle-switch input:checked ~ .toggle-track {
  background: var(--primary);
  border-color: var(--primary);
}
.toggle-switch input:checked ~ .toggle-track .toggle-thumb {
  left: calc(100% - 18px);
}

/* Multi-step form progress stepper */
.form-stepper {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 28px;
  counter-reset: step;
}
.form-stepper-step {
  display: flex;
  align-items: center;
  flex: 1;
  position: relative;
}
.form-stepper-step:last-child { flex: none; }
.form-stepper-dot {
  width: 32px;
  height: 32px;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 2px solid var(--border-light);
  background: #fff;
  color: var(--text-muted-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
  transition: background var(--t-base), border-color var(--t-base), color var(--t-base);
  z-index: 1;
}
.form-stepper-step.is-active .form-stepper-dot {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(29,185,84,.18);
  animation: ir-pulse-ring 1.4s ease infinite;
}
.form-stepper-step.is-done .form-stepper-dot {
  background: var(--primary-soft);
  border-color: var(--primary);
  color: var(--primary-dark);
}
.form-stepper-line {
  flex: 1;
  height: 2px;
  background: var(--border-light);
  transition: background var(--t-slow);
}
.form-stepper-step.is-done .form-stepper-line { background: var(--primary); }
.form-stepper-label {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted-dark);
  white-space: nowrap;
}
.form-stepper-step.is-active .form-stepper-label { color: var(--primary-dark); }

/* -- Bulk action floating bar -- */
.bulk-action-bar {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--bg-dark);
  color: var(--text-light);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: var(--shadow-lg);
  z-index: 9000;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-base), transform var(--t-base);
  font-size: var(--text-sm);
  font-weight: 600;
  white-space: nowrap;
}
.bulk-action-bar.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.bulk-action-bar .btn {
  min-height: 30px;
  padding: 5px 14px;
  font-size: 13px;
  border-color: rgba(255,255,255,.25);
  color: #fff;
  background: rgba(255,255,255,.1);
}
.bulk-action-bar .btn:hover { background: rgba(255,255,255,.2); }

/* -- Danger button variant -- */
.btn-danger, .btn.danger {
  background: var(--danger);
  border-color: var(--danger);
  color: #fff;
}
.btn-danger:hover, .btn.danger:hover {
  background: #b01f28;
  border-color: #b01f28;
  color: #fff;
}

/* -- Status badge info/amber/purple variants -- */
.status-badge.info, .badge-info {
  background: var(--color-info-soft);
  color: #0369a1;
  border-color: var(--color-info-border);
}
.status-badge.amber, .badge-amber {
  background: var(--color-amber-soft);
  color: #92400e;
  border-color: var(--color-amber-border);
}
.status-badge.purple, .badge-purple {
  background: var(--color-purple-soft);
  color: #5b21b6;
  border-color: var(--color-purple-border);
}

/* -- Offline banner -- */
.offline-banner {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--bg-dark-2);
  color: var(--accent-green);
  text-align: center;
  font-size: var(--text-sm);
  font-weight: 600;
  padding: 8px;
  z-index: 9990;
  transition: transform var(--t-base);
}
body.is-offline .offline-banner { display: block !important; }

/* -- Drag upload zone modernisation -- */
.drag-upload-zone {
  border: 2px dashed var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 28px 20px;
  text-align: center;
  background: var(--bg-light);
  transition: background var(--t-fast), border-color var(--t-fast);
  cursor: default;
}
.drag-upload-zone strong { display: block; font-weight: 700; color: var(--text-dark); margin-bottom: 4px; }
.drag-upload-zone span  { color: var(--text-muted-dark); font-size: var(--text-sm); }
.drag-upload-zone.is-over {
  background: var(--primary-soft);
  border-color: var(--primary);
}
.drag-upload-progress {
  margin-top: 12px;
  height: 6px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--border-light);
  overflow: hidden;
}
.drag-upload-progress i {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--primary);
  border-radius: var(--inrep-radius, 10px) !important;
  transition: width .6s ease;
}

/* -- Shortcut modal polish -- */
.shortcut-modal {
  position: fixed;
  inset: 0;
  background: rgba(10,31,21,.55);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9990;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-base);
}
.shortcut-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}
.shortcut-card {
  background: #fff;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 24px;
  width: min(440px, calc(100vw - 32px));
  box-shadow: var(--shadow-lg);
  animation: ir-scale-in .2s ease both;
}
.shortcut-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 0;
  border-bottom: 1px solid var(--border-light);
  font-size: var(--text-sm);
}
.shortcut-row:last-child { border: 0; }
.shortcut-row kbd {
  background: var(--bg-light);
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 2px 8px;
  font-size: 12px;
  font-family: var(--font-body);
  font-weight: 700;
  color: var(--text-dark);
  box-shadow: 0 2px 0 var(--border-light);
}

/* -- Mobile wizard nav polish -- */
.mobile-wizard-nav {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 14px;
  scrollbar-width: none;
  border-bottom: 1px solid var(--border-light);
  margin-bottom: 20px;
}
.mobile-wizard-nav::-webkit-scrollbar { display: none; }
.mobile-wizard-nav button {
  white-space: nowrap;
  padding: 6px 14px;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1.5px solid var(--border-light);
  background: #fff;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted-dark);
  transition: all var(--t-fast);
}
.mobile-wizard-nav button.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* Auth login SSO layout fix */
.auth-card--inrep .auth-divider{display:flex;align-items:center;gap:12px;width:100%;margin:10px 0 8px;color:#6b7a70;font-weight:700}
.auth-card--inrep .auth-divider::before,.auth-card--inrep .auth-divider::after{content:"";height:1px;flex:1;background:#dfe9e2}
.auth-card--inrep .auth-sso-buttons{display:grid!important;grid-template-columns:1fr!important;gap:10px!important;width:100%!important;margin:0 0 18px!important}
.auth-card--inrep .auth-sso-btn{display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;min-height:50px!important;margin:0!important;border-radius:var(--inrep-radius, 10px) !important;text-align:center!important;font-weight:800!important;white-space:normal!important}
.auth-card--inrep .auth-links{text-align:center!important;margin-top:14px!important}
@media (max-width:640px){.auth-card--inrep .auth-sso-btn{min-height:48px!important}.auth-card--inrep .auth-divider{margin-top:8px!important}}

/* 20260514: auth SSO icons, forgot-password alignment, nav pending badges */
.auth-card--inrep .auth-sso-btn .sso-provider-icon{
  width:22px!important;
  height:22px!important;
  display:inline-grid!important;
  place-items:center!important;
  flex:0 0 22px!important;
}
.auth-card--inrep .auth-sso-btn .sso-provider-icon svg{
  width:22px!important;
  height:22px!important;
  display:block!important;
}
.auth-card--inrep .auth-sso-btn span:last-child{
  line-height:1.2!important;
}
.forgot-password-page{
  min-height:100dvh!important;
  padding:24px!important;
}
.forgot-password-card{
  width:min(520px,calc(100vw - 48px))!important;
  max-width:520px!important;
  padding:40px!important;
  margin:0!important;
}
.forgot-password-card .auth-logo{
  margin-bottom:26px!important;
}
.forgot-password-subtitle{
  text-align:left!important;
  margin:-10px 0 22px!important;
  line-height:1.55!important;
}
.forgot-password-form{
  display:grid!important;
  gap:16px!important;
  width:100%!important;
}
.forgot-password-form .form-group{
  margin:0!important;
}
.forgot-password-card .auth-links{
  margin:18px 0 0!important;
}
.admin-sidebar-link,
.admin-icon-btn,
.admin-mobile-action{
  position:relative!important;
}
.admin-sidebar-link .admin-count-badge{
  top:4px!important;
  right:7px!important;
  z-index:2!important;
}
body:not(.admin-sidebar-collapsed) .admin-sidebar-link .admin-count-badge{
  top:50%!important;
  right:34px!important;
  transform:translateY(-50%)!important;
}
.admin-mobile-action .admin-count-badge{
  top:4px!important;
  right:16px!important;
}
.admin-topbar-action-labeled .admin-count-badge,
.admin-notification-bell .admin-count-badge{
  top:-6px!important;
  right:-6px!important;
}
@media(max-width:640px){
  .forgot-password-page{padding:16px!important;}
  .forgot-password-card{width:min(100%,calc(100vw - 24px))!important;padding:28px 22px!important;border-radius:var(--inrep-radius, 10px) !important;}
  .forgot-password-subtitle{text-align:left!important;}
}

/* Subscription currency selector fix */
.subscription-currency-tabs{margin-top:10px!important}
.subscription-currency-note{max-width:760px;margin:10px 0 22px!important;padding:12px 14px;border:1px solid var(--border-light,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:var(--bg-light,#f8fafc);color:var(--muted,#64748b)}

/* -- Table search + filter toolbar (TES, JS-injected) --------------------- */
.tes {
  --tes-bg: #ffffff;
  --tes-border: #e5e7eb;
  --tes-border-strong: #d1d5db;
  --tes-text: #0f172a;
  --tes-muted: #6b7280;
  --tes-muted-soft: #9ca3af;
  --tes-accent: #1db954;
  --tes-accent-soft: rgba(29,185,84,.12);
  --tes-shadow-sm: 0 1px 2px rgba(15,23,42,.04);
  --tes-shadow-focus: 0 0 0 4px rgba(29,185,84,.16);
  --tes-radius: 12px;
  --tes-radius-sm: 999px;
  --tes-anim: cubic-bezier(.32,.72,0,1);

  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin: 0 0 14px !important;
  padding: 10px 12px !important;
  background: var(--tes-bg) !important;
  border: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: var(--tes-shadow-sm) !important;
  font-family: inherit !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--tes-text) !important;
  /* entrance state */
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .35s var(--tes-anim), transform .35s var(--tes-anim), border-color .2s ease, box-shadow .2s ease;
}
.tes.is-mounted {
  opacity: 1;
  transform: translateY(0);
}
.tes.is-filtering {
  border-color: var(--tes-accent) !important;
}
.tes *, .tes *::before, .tes *::after { box-sizing: border-box; }

.tes__row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  margin: 0 !important;
}
.tes__row--filters {
  padding-top: 4px !important;
  border-top: 1px dashed var(--tes-border) !important;
}

/* -- Search ------------------------------------------------------------- */
/* Architecture: single .tes__search wrapper has the border + background.
   The <input> fills the wrapper completely with internal padding. Icon and
   trailing controls are absolute-positioned overlays that DO NOT have any
   border, background, or box-shadow that could be hijacked by global form
   CSS. The user only ever sees ONE bordered box. */
.tes__search {
  position: relative !important;
  display: block !important;
  flex: 1 1 280px !important;
  height: 40px !important;
  min-width: 200px !important;
  max-width: 520px !important;
  background: #f9fafb !important;
  border: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.tes__search:hover { border-color: var(--tes-border-strong) !important; }
.tes__search:focus-within {
  background: #fff !important;
  border-color: var(--tes-accent) !important;
  box-shadow: var(--tes-shadow-focus) !important;
}

.tes .tes__search .tes__input,
.tes .tes__search input.tes__input,
.tes .tes__search input[class="tes__input"] {
  display: block !important;
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding-top: 0 !important;
  padding-right: 76px !important;
  padding-bottom: 0 !important;
  padding-left: 40px !important;
  padding-inline-start: 40px !important;
  padding-inline-end: 76px !important;
  padding-block-start: 0 !important;
  padding-block-end: 0 !important;
  text-indent: 0 !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  color: var(--tes-text) !important;
  box-shadow: none !important;
  border-radius: var(--inrep-radius, 10px) !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.tes .tes__input::placeholder {
  color: var(--tes-muted-soft) !important;
  font-weight: 400 !important;
  font-style: normal !important;
  opacity: 1 !important;
  transition: opacity .2s ease;
}
.tes__search:focus-within .tes__input::placeholder { opacity: .5 !important; }
.tes .tes__input:focus,
.tes .tes__input:focus-visible {
  outline: 0 !important;
  box-shadow: none !important;
  border: 0 !important;
}
.tes .tes__input::-webkit-search-cancel-button,
.tes .tes__input::-webkit-search-decoration { display: none !important; -webkit-appearance: none !important; }
.tes .tes__input::-webkit-contacts-auto-fill-button,
.tes .tes__input::-webkit-credentials-auto-fill-button { display: none !important; visibility: hidden !important; }

/* Icon overlay - absolute, no border/background, can't be styled as a box */
.tes__search-icon {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--tes-muted) !important;
  pointer-events: none !important;
  z-index: 2 !important;
  transition: color .2s ease, transform .25s var(--tes-anim);
}
.tes__search-icon svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
  background: transparent !important;
  border: 0 !important;
}
.tes__search:focus-within .tes__search-icon {
  color: var(--tes-accent) !important;
  transform: translateY(-50%) scale(1.08);
}

/* Trailing controls - absolute on the right side */
.tes__trailing {
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  z-index: 2 !important;
}

.tes__clear {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  margin: 0 !important;
  padding: 0 !important;
  background: rgba(15,23,42,.06) !important;
  color: var(--tes-muted) !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  cursor: pointer !important;
  box-shadow: none !important;
  opacity: 0;
  transform: scale(.6);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s var(--tes-anim), background .2s ease, color .2s ease;
}
.tes__search.has-value .tes__clear {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}
.tes__clear:hover { background: rgba(15,23,42,.12) !important; color: var(--tes-text) !important; }
.tes__clear svg { width: 12px !important; height: 12px !important; display: block !important; }

.tes__kbd {
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 20px !important;
  height: 20px !important;
  padding: 0 6px !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: var(--tes-muted) !important;
  background: #fff !important;
  border: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: inset 0 -1px 0 var(--tes-border) !important;
  transition: opacity .2s ease;
}
@media (min-width: 768px) {
  .tes__search:not(.has-value):not(:focus-within) .tes__kbd { display: inline-flex !important; }
}

/* -- Meta (count + reset) ----------------------------------------------- */
.tes__meta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-left: auto !important;
  flex: 0 0 auto !important;
}
.tes__count {
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 2px !important;
  padding: 6px 10px !important;
  background: #f3f4f6 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--tes-muted) !important;
  white-space: nowrap !important;
  transition: background .25s ease, color .25s ease;
}
.tes.is-filtering .tes__count {
  background: var(--tes-accent-soft) !important;
  color: #0f5d2b !important;
}
.tes__count-value {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--tes-text) !important;
  display: inline-block !important;
  transform-origin: center;
}
.tes.is-filtering .tes__count-value { color: var(--tes-accent) !important; }
.tes__count-value--bump { animation: tes-bump .35s var(--tes-anim); }
@keyframes tes-bump {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.22); }
  100% { transform: scale(1); }
}

.tes__reset {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  height: 32px !important;
  padding: 0 12px 0 8px !important;
  font-family: inherit !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #b91c1c !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: var(--inrep-radius, 10px) !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s var(--tes-anim);
  animation: tes-slide-in .26s var(--tes-anim) both;
}
.tes__reset[hidden] { display: none !important; }
.tes__reset:hover { background: #fef2f2 !important; border-color: #fecaca !important; }
.tes__reset:active { transform: scale(.96); }
.tes__reset svg { width: 11px !important; height: 11px !important; }
@keyframes tes-slide-in {
  from { opacity: 0; transform: translateX(6px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* -- Filter chips ------------------------------------------------------- */
.tes__filters-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  color: var(--tes-muted) !important;
  margin-right: 2px !important;
}
.tes__filters-label svg { width: 13px !important; height: 13px !important; }

.tes__chip-wrap {
  position: relative !important;
  display: inline-block !important;
  opacity: 0;
  transform: translateY(4px);
  animation: tes-chip-in .35s var(--tes-anim) forwards;
  animation-delay: var(--tes-chip-delay, 0ms);
}
@keyframes tes-chip-in {
  to { opacity: 1; transform: translateY(0); }
}

.tes button.tes__chip {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  height: 32px !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 10px !important;
  background: #fff !important;
  border: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-family: inherit !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  color: #374151 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s var(--tes-anim);
}
.tes__chip:hover {
  border-color: var(--tes-border-strong) !important;
  background: #f9fafb !important;
}
.tes__chip:focus-visible {
  outline: 0 !important;
  border-color: var(--tes-accent) !important;
  box-shadow: var(--tes-shadow-focus) !important;
}
.tes__chip.is-active {
  background: var(--tes-accent-soft) !important;
  border-color: var(--tes-accent) !important;
  color: #0f5d2b !important;
}
.tes__chip-label {
  color: var(--tes-muted) !important;
  font-weight: 600 !important;
  letter-spacing: .01em !important;
  transition: color .18s ease;
}
.tes__chip.is-active .tes__chip-label { color: var(--tes-accent) !important; }
.tes__chip-value {
  display: inline-flex !important;
  align-items: center !important;
  max-width: 140px !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  color: #111827 !important;
  font-weight: 600 !important;
}
.tes__chip-value:empty { display: none !important; }
.tes__chip.is-active .tes__chip-value { color: var(--tes-accent) !important; }
.tes__chip-caret {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 10px !important;
  height: 10px !important;
  margin-left: 2px !important;
  color: var(--tes-muted) !important;
  pointer-events: none !important;
  transition: transform .2s var(--tes-anim), color .18s ease;
}
.tes__chip:hover .tes__chip-caret { color: var(--tes-text) !important; }
.tes__chip.is-active .tes__chip-caret { color: var(--tes-accent) !important; }
.tes__chip-wrap.is-open .tes__chip-caret { transform: rotate(180deg); }

/* -- Filter menu popover ----------------------------------------------- */
.tes__menu {
  position: absolute !important;
  top: calc(100% + 6px) !important;
  left: 0 !important;
  z-index: 100 !important;
  min-width: 200px !important;
  max-width: 280px !important;
  max-height: 280px !important;
  padding: 4px !important;
  background: #fff !important;
  border: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 12px 32px rgba(15,23,42,.12), 0 2px 4px rgba(15,23,42,.06) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: thin !important;
  transform-origin: top left;
  animation: tes-menu-in .18s var(--tes-anim) both;
}
.tes__menu[hidden] { display: none !important; }
@keyframes tes-menu-in {
  from { opacity: 0; transform: translateY(-4px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.tes__menu::-webkit-scrollbar { width: 6px; }
.tes__menu::-webkit-scrollbar-track { background: transparent; }
.tes__menu::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: var(--inrep-radius, 10px) !important; }

.tes button.tes__menu-item {
  display: flex !important;
  width: 100% !important;
  align-items: center !important;
  gap: 8px !important;
  height: 34px !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 10px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-family: inherit !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  line-height: 1 !important;
  text-align: left !important;
  color: #1f2937 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transition: background .12s ease, color .12s ease;
}
.tes__menu-item:hover,
.tes__menu-item.is-focus,
.tes__menu-item:focus-visible {
  outline: 0 !important;
  background: #f3f4f6 !important;
}
.tes__menu-item[aria-selected="true"] {
  background: var(--tes-accent-soft) !important;
  color: #0f5d2b !important;
  font-weight: 600 !important;
}
.tes__menu-item[aria-selected="true"]:hover,
.tes__menu-item[aria-selected="true"].is-focus {
  background: rgba(29,185,84,.18) !important;
}
.tes__menu-item.is-all {
  border-bottom: 1px solid var(--tes-border) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  margin-bottom: 2px !important;
  color: var(--tes-muted) !important;
  font-weight: 600 !important;
}
.tes__menu-item.is-all[aria-selected="true"] { color: var(--tes-accent) !important; }
.tes__menu-item-check {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 14px !important;
  height: 14px !important;
  flex: none !important;
  color: var(--tes-accent) !important;
  opacity: 0;
  transform: scale(.6);
  transition: opacity .15s ease, transform .15s var(--tes-anim);
}
.tes__menu-item[aria-selected="true"] .tes__menu-item-check {
  opacity: 1;
  transform: scale(1);
}
.tes__menu-item-label {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* -- Row hide animation ------------------------------------------------- */
tr.tes-row-hidden { display: none !important; }

/* -- No-results state --------------------------------------------------- */
.tes-no-results .tes-no-results__cell {
  padding: 36px 16px !important;
  text-align: center !important;
  background: #f9fafb !important;
}
.tes-no-results__inner {
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 6px !important;
  color: var(--tes-muted, #6b7280) !important;
  animation: tes-fade-in .3s ease;
}
.tes-no-results__icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  margin-bottom: 4px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29,185,84,.10) !important;
  color: #1db954 !important;
  animation: tes-spark 2.4s ease-in-out infinite;
}
.tes-no-results__title {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #111827 !important;
}
.tes-no-results__hint {
  font-size: 12px !important;
  color: #6b7280 !important;
  font-style: normal !important;
}
@keyframes tes-fade-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes tes-spark {
  0%,100% { transform: rotate(0deg) scale(1); }
  50%     { transform: rotate(8deg) scale(1.06); }
}

/* -- Mobile -------------------------------------------------------------- */
@media (max-width: 640px) {
  .tes { padding: 8px 10px !important; }
  .tes__search { flex-basis: 100% !important; max-width: none !important; }
  .tes__meta { width: 100% !important; justify-content: space-between !important; margin-left: 0 !important; }
  .tes__row--filters { gap: 6px !important; }
  .tes__chip { height: 30px !important; font-size: 11.5px !important; }
}

/* -- Reduced motion ----------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .tes, .tes *, .tes *::before, .tes *::after {
    animation: none !important;
    transition: none !important;
  }
  .tes { opacity: 1; transform: none; }
  .tes__chip { opacity: 1; transform: none; }
}

/* -- Impersonation banner - authoritative reset (3 earlier blocks conflict) - */
.impersonation-floating-stop {
  position: fixed !important;
  top: auto !important;
  right: 16px !important;
  bottom: 16px !important;
  left: auto !important;
  z-index: 2147483000 !important;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  gap: 10px !important;
  width: auto !important;
  max-width: min(420px, calc(100vw - 32px)) !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 8px 12px !important;
  margin: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #111827 !important;
  color: #fff !important;
  box-shadow: 0 10px 28px rgba(15,23,42,.28) !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  animation: none !important;
  isolation: isolate;
}
.impersonation-floating-stop > * {
  flex: 0 0 auto !important;
}
.impersonation-floating-stop .impersonation-floating-stop-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  color: #fff !important;
}
.impersonation-floating-stop .impersonation-floating-stop-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f87171 !important;
  box-shadow: 0 0 0 3px rgba(248,113,113,.25) !important;
  animation: none !important;
  flex: none !important;
}
.impersonation-floating-stop .inline-form,
.impersonation-floating-stop form {
  display: inline-flex !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  height: auto !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.impersonation-floating-stop .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 30px !important;
  height: 30px !important;
  padding: 0 12px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  background: #fff !important;
  color: #b91c1c !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: none !important;
  width: auto !important;
}
.impersonation-floating-stop .btn:hover,
.impersonation-floating-stop .btn:focus-visible {
  background: #fee2e2 !important;
  color: #7f1d1d !important;
}
@media (max-width: 640px) {
  .impersonation-floating-stop {
    top: auto !important;
    bottom: 16px !important;
    right: 12px !important;
    left: 12px !important;
    max-width: none !important;
    justify-content: space-between !important;
  }
}

/* -- Pill / button content breathing room ---------------------------------
   When a button or pill contains both an icon (svg) and a text node, give
   them flex layout + a sensible gap. Catches the "icon glued to text" pattern
   on custom widgets like the Ask Inrep launcher, status pills, dropdown
   triggers, etc. - without touching elements that already declare flex. */
.site-chatbot-toggle,
.btn,
.pill,
.badge,
.status-badge,
.tag,
.chip,
.access-badge {
  column-gap: 8px;
}
.site-chatbot-toggle > svg,
.site-chatbot-toggle > span,
.btn > svg,
.btn > span,
.pill > svg,
.pill > span,
.status-badge > svg,
.status-badge > span,
.tag > svg,
.tag > span {
  vertical-align: middle;
}
/* For lay-out-naive custom pill buttons that have not declared flex yet: */
button.pill-toggle,
button.chip-toggle,
a.pill-toggle,
.kpi-pill,
.tag-pill,
.glance-pill,
.action-pill,
.mini-pill,
.summary-pill {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 32px !important;
  padding: 6px 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}
/* SVG inside pill-like containers should never collapse */
.pill > svg, .badge > svg, .status-badge > svg, .chip > svg, .tag > svg,
.kpi-pill > svg, .tag-pill > svg, .glance-pill > svg, .action-pill > svg {
  flex: none !important;
  width: 14px;
  height: 14px;
}
/* Inline floating action buttons (FAB-style) - common cramping spot */
.fab,
.floating-action,
.floating-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 44px !important;
  padding: 10px 18px !important;
  border-radius: var(--inrep-radius, 10px) !important;
}

/* -- Kill the empty scrollable space below tables ------------------------
   The legacy .admin-table-wrap rules combine 20px bottom padding, a fat
   horizontal scrollbar gutter, and `overflow: auto` - together they leave a
   ~30px empty band beneath every table. Strip the bottom padding, lock
   overflow-y to visible, and slim the horizontal scrollbar to 6px. */
.admin-table-wrap,
.table-responsive {
  padding-bottom: 0 !important;
  overflow-y: visible !important;
  overflow-x: auto !important;
  scrollbar-width: thin !important;
  scrollbar-color: #d1d5db transparent !important;
  scrollbar-gutter: auto !important;
}
.admin-table-wrap > table,
.table-responsive > table {
  margin-bottom: 0 !important;
}
.admin-table-wrap > table:last-child tbody tr:last-child td,
.table-responsive > table:last-child tbody tr:last-child td {
  border-bottom: 0 !important;
}
/* Slim horizontal scrollbar (WebKit / Chromium / Edge / Safari) */
.admin-table-wrap::-webkit-scrollbar,
.table-responsive::-webkit-scrollbar {
  height: 6px !important;
  width: 6px !important;
  background: transparent !important;
}
.admin-table-wrap::-webkit-scrollbar-thumb,
.table-responsive::-webkit-scrollbar-thumb {
  background: #d1d5db !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.admin-table-wrap::-webkit-scrollbar-thumb:hover,
.table-responsive::-webkit-scrollbar-thumb:hover {
  background: #9ca3af !important;
}
.admin-table-wrap::-webkit-scrollbar-track,
.table-responsive::-webkit-scrollbar-track {
  background: transparent !important;
}
/* When the table fits without horizontal scroll, hide the scrollbar entirely */
@media (min-width: 1100px) {
  .admin-table-wrap.has-no-overflow::-webkit-scrollbar,
  .table-responsive.has-no-overflow::-webkit-scrollbar { display: none !important; }
}

/* -- Kill the empty scrollable void below short pages ---------------------
   Several panels and the admin-table-wrap can be stretched taller than their
   content by parent flex/grid containers, by lingering min-height values, or
   by `.admin-page { padding-bottom }`. The result is a giant white scrollable
   band beneath a tiny table. Force these containers to size to their content,
   and make the admin-main use a content-driven height so it never reserves
   extra empty vertical space. */
.admin-main > .admin-page {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  min-height: 0 !important;
  height: auto !important;
  padding-bottom: 24px !important;
}
.admin-main > .admin-page > * {
  flex: 0 0 auto !important;
  min-height: 0 !important;
}
.admin-panel,
.admin-panel-body,
.admin-table-wrap,
.table-responsive {
  min-height: 0 !important;
  height: auto !important;
  align-self: stretch;
}
.admin-table-wrap > table,
.table-responsive > table {
  height: auto !important;
}
/* Let admin-main grow with content but never force extra empty space. The
   shell's overflow:hidden still prevents a second scrollbar at the body. */
.admin-main {
  height: auto !important;
  min-height: calc(100dvh - 64px) !important;
  max-height: calc(100dvh - 64px) !important;
  overflow-y: auto !important;
}
/* On the projects/repository page specifically, the bulk-bar + table can mis-
   wrap into an over-tall column. Lock the bulk-bar to natural height. */
.table-bulk-bar { min-height: 0 !important; height: auto !important; padding: 10px 14px !important; }

/* 2026-05-16: research portal and national search layout repair */
.research-portal-page .mkt-page,
.national-search-page .mkt-page {
  background: #fff;
  color: #0b1710;
}
.research-shell {
  width: min(1180px, calc(100% - 40px));
  margin-inline: auto;
}
.research-portal-page .mkt-page > section,
.national-search-page .mkt-page > section {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.portal-kicker {
  width: max-content;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 14px;
  padding: 5px 12px;
  border: 1px solid rgba(29, 185, 84, .3);
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29, 185, 84, .08);
  color: #0f6b2f;
  font-size: 11px;
  font-weight: 750;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.research-portal-hero {
  padding: clamp(64px, 7vw, 104px) 0 clamp(38px, 5vw, 64px) !important;
  background:
    radial-gradient(circle at 78% 16%, rgba(34, 197, 94, .12), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #f8fbf8 100%);
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}
.research-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.research-hero-copy h1,
.national-hero h1 {
  max-width: 820px;
  margin: 0 0 16px;
  color: #071b11;
  font-family: var(--font-display, Sora, sans-serif);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.04;
  letter-spacing: -.045em;
}
.research-hero-copy p,
.national-hero p {
  max-width: 680px;
  margin: 0;
  color: #4d6358;
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.7;
}
.portal-search {
  width: min(760px, 100%);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  margin: 28px 0 16px;
  padding: 9px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, .09);
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: 0 20px 55px rgba(15, 23, 42, .08);
}
.portal-search input {
  width: 100% !important;
  min-height: 50px;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 15px !important;
  color: #0f2418 !important;
}
.portal-search button {
  min-height: 50px;
  border-radius: var(--inrep-radius, 10px) !important;
  padding-inline: 26px !important;
}
.portal-quicklinks {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}
.portal-quicklinks .btn {
  min-height: 42px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  color: #08712a;
  border: 1px solid rgba(7, 112, 42, .18);
  box-shadow: none;
}
.portal-stats-card {
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .08);
}
.portal-card-label {
  width: max-content;
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 18px;
  padding: 5px 12px;
  border: 1px solid rgba(29, 185, 84, .3);
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29, 185, 84, .08);
  color: #0f6b2f;
  font-size: 11px;
  font-weight: 750;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.portal-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
}
.portal-stat-item {
  min-height: 112px;
  display: grid;
  align-content: center;
  justify-items: center;
  padding: 22px 18px;
  border-right: 1px solid rgba(15, 23, 42, .08);
  border-bottom: 1px solid rgba(15, 23, 42, .08);
  background: transparent;
  text-align: center;
}
.portal-stat-item:nth-child(2n) {
  border-right: 0;
}
.portal-stat-item:nth-last-child(-n + 2) {
  border-bottom: 0;
}
.portal-stat-item strong {
  display: block;
  color: #0f172a;
  font-family: var(--font-display, Sora, sans-serif);
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1;
  letter-spacing: -.045em;
}
.portal-stat-item span {
  margin-top: 8px;
  color: #627267;
  font-size: 13px;
  font-weight: 800;
}
.research-section {
  padding: clamp(54px, 6vw, 84px) 0 !important;
}
.research-section + .research-section {
  border-top: 1px solid rgba(15, 23, 42, .06);
}
.research-section-head {
  max-width: 720px;
  margin: 0 auto 28px;
  text-align: center;
}
.research-section-head span {
  display: block;
  margin-bottom: 6px;
  color: #08712a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.research-section-head h2 {
  margin: 0;
  color: #071b11;
  font-size: clamp(25px, 3vw, 36px);
  line-height: 1.15;
  letter-spacing: -.03em;
}
.research-section-head p {
  margin: 10px auto 0;
  color: #64756c;
  line-height: 1.65;
}
.portal-record-grid,
.national-results-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.portal-record-card,
.national-record-card,
.portal-empty-card,
.national-empty-state {
  min-width: 0;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 16px 46px rgba(15, 23, 42, .055);
}
.portal-record-card {
  min-height: 160px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px;
  color: #0b1710;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.portal-record-card:hover {
  transform: translateY(-2px);
  border-color: rgba(22, 163, 74, .24);
  box-shadow: 0 22px 60px rgba(15, 23, 42, .09);
}
.portal-record-card strong,
.national-record-card h3 {
  color: #071b11;
  font-family: var(--font-display, Sora, sans-serif);
  font-size: 17px;
  line-height: 1.38;
  letter-spacing: -.015em;
}
.portal-record-card span,
.portal-record-card small {
  color: #64756c;
  line-height: 1.5;
}
.portal-record-card small {
  margin-top: auto;
  font-weight: 700;
}
.portal-empty-card,
.national-empty-state {
  grid-column: 1 / -1;
  padding: 26px;
  color: #64756c;
  text-align: center;
}
.portal-topic-cloud {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.portal-topic-cloud a,
.national-pill-row .pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 13px;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid rgba(22, 163, 74, .18);
  background: #eefdf3;
  color: #166534;
  font-size: 12px;
  font-weight: 850;
  text-decoration: none;
}
.portal-topic-cloud small {
  color: #4d6358;
  font-weight: 900;
}
.portal-table-card {
  overflow-x: auto;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 16px 46px rgba(15, 23, 42, .055);
}
.portal-ranking-table {
  width: 100%;
  min-width: 720px;
  border-collapse: separate;
  border-spacing: 0;
}
.portal-ranking-table th,
.portal-ranking-table td {
  padding: 16px 20px;
  border-bottom: 1px solid rgba(15, 23, 42, .07);
  text-align: left;
}
.portal-ranking-table th {
  background: #f5faf6;
  color: #64756c;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.portal-ranking-table tr:last-child td {
  border-bottom: 0;
}
.portal-ranking-table a {
  color: #071b11;
  font-weight: 850;
  text-decoration: none;
}
.national-hero {
  padding: clamp(58px, 6vw, 86px) 0 34px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbf8 100%);
  border-bottom: 1px solid rgba(15, 23, 42, .06);
}
.national-hero-inner {
  text-align: center;
}
.national-hero .portal-kicker {
  margin-inline: auto;
}
.national-hero h1,
.national-hero p {
  margin-left: auto;
  margin-right: auto;
}
.national-search-section {
  padding: clamp(34px, 5vw, 62px) 0 clamp(70px, 7vw, 108px) !important;
}
.national-search-form {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(260px, 2fr) minmax(160px, 1fr) minmax(160px, 1fr) minmax(120px, .72fr) auto !important;
  gap: 14px !important;
  align-items: end !important;
  margin: 0 0 30px !important;
  padding: 20px !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 20px 62px rgba(15, 23, 42, .075) !important;
}
.national-search-form label {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
  color: #071b11 !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}
.national-search-form input,
.national-search-form select {
  width: 100% !important;
  min-height: 52px !important;
  border: 1px solid rgba(15, 23, 42, .10) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0b1710 !important;
  padding: 0 15px !important;
  box-shadow: none !important;
}
.national-search-form button {
  min-height: 52px !important;
  padding-inline: 26px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  white-space: nowrap !important;
}
.national-results-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
  margin: 0 0 18px;
}
.national-results-head span {
  display: block;
  margin-bottom: 4px;
  color: #08712a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.national-results-head h2 {
  margin: 0;
  color: #071b11;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.2;
}
.national-record-card {
  display: flex;
  flex-direction: column;
  min-height: 292px;
  padding: 24px;
}
.national-record-card h3 {
  margin: 0 0 12px;
}
.national-record-card h3 a {
  color: inherit;
  text-decoration: none;
}
.national-record-card h3 a:hover {
  color: #08712a;
}
.national-record-card p {
  margin: 0;
  color: #415348;
  line-height: 1.65;
}
.national-card-body {
  flex: 1;
}
.national-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 0;
  margin-top: 18px;
  color: #4d6358;
  font-size: 13px;
  line-height: 1.45;
}
.national-card-meta span {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}
.national-card-meta span + span::before {
  content: '*';
  margin: 0 8px;
  color: #9aac9f;
}
.national-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.national-empty-state strong {
  display: block;
  color: #071b11;
  font-size: 18px;
  margin-bottom: 6px;
}
.national-empty-state p {
  margin: 0;
}
@media (max-width: 1020px) {
  .research-hero-grid {
    grid-template-columns: 1fr;
  }
  .portal-record-grid,
  .national-results-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .national-search-form {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .national-search-keyword {
    grid-column: 1 / -1;
  }
}
@media (max-width: 700px) {
  .research-shell {
    width: min(100% - 28px, 1180px);
  }
  .research-portal-hero,
  .national-hero {
    padding-top: 44px !important;
  }
  .research-hero-copy h1,
  .national-hero h1 {
    font-size: clamp(32px, 11vw, 44px);
  }
  .portal-search,
  .national-search-form {
    grid-template-columns: 1fr !important;
  }
  .portal-search button,
  .national-search-form button {
    width: 100% !important;
  }
  .portal-stat-grid,
  .portal-record-grid,
  .national-results-grid {
    grid-template-columns: 1fr;
  }
  .portal-stat-item,
  .portal-stat-item:nth-child(2n),
  .portal-stat-item:nth-last-child(-n + 2) {
    border-right: 0;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
  }
  .portal-stat-item:last-child {
    border-bottom: 0;
  }
  .portal-quicklinks .btn {
    width: 100%;
    justify-content: center;
  }
  .national-results-head {
    display: block;
  }
  .national-record-card {
    min-height: 0;
    padding: 20px;
  }
}

/* 2026-05-16: exact research portal eyebrow + snapshot correction */
.research-portal-page .research-hero-copy > .portal-kicker,
.national-search-page .national-hero .portal-kicker,
.research-portal-page .portal-card-label {
  display: inline-flex !important;
  align-items: center !important;
  width: max-content !important;
  max-width: 100% !important;
  min-height: 0 !important;
  margin: 0 0 18px !important;
  padding: 5px 12px !important;
  border: 1px solid rgba(29, 185, 84, .3) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29, 185, 84, .08) !important;
  color: #0f6b2f !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.research-portal-page .research-hero-copy > p:not(.portal-kicker),
.national-search-page .national-hero p:not(.portal-kicker) {
  max-width: 680px;
  margin: 0;
  color: #4d6358;
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.7;
}
.research-portal-page .portal-stats-card {
  padding: clamp(22px, 3vw, 32px) !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 24px 70px rgba(15, 23, 42, .08) !important;
}
.research-portal-page .portal-card-label {
  margin-bottom: 18px !important;
}
.research-portal-page .portal-stat-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(15, 23, 42, .08) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: none !important;
}
.research-portal-page .portal-stat-item {
  min-height: 112px !important;
  display: grid !important;
  align-content: center !important;
  justify-items: center !important;
  padding: 22px 18px !important;
  border: 0 !important;
  border-right: 1px solid rgba(15, 23, 42, .08) !important;
  border-bottom: 1px solid rgba(15, 23, 42, .08) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: none !important;
  text-align: center !important;
}
.research-portal-page .portal-stat-item:nth-child(2n) {
  border-right: 0 !important;
}
.research-portal-page .portal-stat-item:nth-last-child(-n + 2) {
  border-bottom: 0 !important;
}
.research-portal-page .portal-stat-item strong {
  display: block !important;
  color: #0f172a !important;
  font-family: var(--font-display, Sora, sans-serif) !important;
  font-size: clamp(30px, 4vw, 42px) !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: -.04em !important;
}
.research-portal-page .portal-stat-item span {
  display: block !important;
  margin-top: 8px !important;
  color: #627267 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
@media (max-width: 700px) {
  .research-portal-page .portal-stat-grid {
    grid-template-columns: 1fr !important;
  }
  .research-portal-page .portal-stat-item,
  .research-portal-page .portal-stat-item:nth-child(2n),
  .research-portal-page .portal-stat-item:nth-last-child(-n + 2) {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(15, 23, 42, .08) !important;
  }
  .research-portal-page .portal-stat-item:last-child {
    border-bottom: 0 !important;
  }
}

/* Repository feature suite */
.feature-matrix{display:grid;gap:.75rem}.feature-row{display:grid;grid-template-columns:auto 1fr auto;gap:.9rem;align-items:start;padding:1rem;border:1px solid var(--border-color,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:#fff;text-decoration:none;color:inherit}.feature-row:hover{box-shadow:0 12px 28px rgba(15,23,42,.08);transform:translateY(-1px)}.feature-no{display:grid;place-items:center;width:2rem;height:2rem;border-radius:var(--inrep-radius, 10px) !important;background:var(--primary-50,#ecfdf5);color:var(--primary,#047857);font-weight:800}.feature-row small{display:block;margin-top:.25rem;color:var(--muted,#64748b);line-height:1.45}.feature-row em{font-style:normal;font-size:.75rem;font-weight:700;color:var(--primary,#047857);background:var(--primary-50,#ecfdf5);border-radius:var(--inrep-radius, 10px) !important;padding:.35rem .55rem}.score-pill{display:inline-flex;align-items:center;border-radius:var(--inrep-radius, 10px) !important;padding:.3rem .6rem;font-weight:800;font-size:.82rem}.score-good{background:#ecfdf5;color:#047857}.score-warn{background:#fffbeb;color:#b45309}.score-bad{background:#fef2f2;color:#b91c1c}.check-list{display:grid;gap:.7rem}.check-row{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;border:1px solid var(--border-color,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;padding:.8rem}.check-row span{display:grid;place-items:center;width:1.6rem;height:1.6rem;border-radius:var(--inrep-radius, 10px) !important;font-weight:900}.check-row.ok span{background:#ecfdf5;color:#047857}.check-row.fail span{background:#fef2f2;color:#b91c1c}.topic-cloud{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0 1.25rem}.topic-cloud span{display:inline-flex;gap:.4rem;align-items:center;border:1px solid var(--border-color,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;padding:.45rem .65rem;background:#fff}.compact-list{display:grid;gap:.65rem}.compact-list>div{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;border:1px solid var(--border-color,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:#fff}.trend-bars{display:grid;gap:.65rem}.trend-row{display:grid;grid-template-columns:minmax(9rem,1fr) 2fr auto;gap:.8rem;align-items:center}.trend-row meter{width:100%;height:.7rem}.verification-slip{max-width:900px;margin:0 auto;background:#fff;padding:2rem}.slip-header{display:flex;justify-content:space-between;gap:2rem;border-bottom:2px solid #111827;padding-bottom:1rem;margin-bottom:1.5rem}.qr-box{display:grid;place-items:center;width:130px;height:130px;border:2px dashed #111827;border-radius:var(--inrep-radius, 10px) !important;text-align:center}.qr-box span{font-size:2rem;font-weight:900}.slip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin:1.5rem 0}.slip-grid div{border:1px solid #e5e7eb;border-radius:var(--inrep-radius, 10px) !important;padding:.8rem}.slip-grid dt{font-size:.75rem;text-transform:uppercase;color:#64748b}.slip-grid dd{margin:0;font-weight:700}.metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.metric-strip>div{border:1px solid var(--border-color,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:#fff;padding:1.1rem}.metric-strip strong{display:block;font-size:1.8rem}.metric-strip span{color:var(--muted,#64748b)}@media(max-width:780px){.feature-row,.check-row,.trend-row{grid-template-columns:1fr}.feature-no{width:1.8rem;height:1.8rem}.metric-strip,.slip-grid{grid-template-columns:1fr}.slip-header{display:block}.qr-box{margin-top:1rem}}
.qr-box img{max-width:112px;max-height:112px;display:block}

/* 2026-05-18: repository admin layout repair */
.repository-suite-page .suite-stats,
.record-quality-page .record-quality-stats {
  align-items: stretch !important;
  gap: clamp(12px, 2vw, 20px) !important;
}
.repository-suite-page .stat-card,
.record-quality-page .stat-card {
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  gap: 10px !important;
  min-height: 108px !important;
  padding: 18px 20px !important;
  align-content: center !important;
  justify-items: start !important;
  text-align: left !important;
}
.repository-suite-page .stat-card-metric,
.record-quality-page .stat-card-metric {
  display: flex !important;
  align-items: baseline !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  min-width: 0 !important;
}
.repository-suite-page .stat-card-metric span,
.record-quality-page .stat-card-metric span {
  display: inline !important;
  margin: 0 !important;
  color: #0f172a !important;
  font-size: clamp(15px, 1.2vw, 18px) !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  line-height: 1.35 !important;
  text-transform: none !important;
}
.repository-suite-page .stat-card-metric strong,
.record-quality-page .stat-card-metric strong {
  display: inline !important;
  color: #0f172a !important;
  font-size: clamp(24px, 2.1vw, 30px) !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}
.repository-suite-page .stat-card > small,
.record-quality-page .stat-card > small {
  display: block !important;
  margin: 0 !important;
  max-width: 100% !important;
  color: #3f5148 !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
.record-quality-page .stat-card a {
  color: #0f6b2f !important;
  font-weight: 750 !important;
  text-decoration: none !important;
}
.repository-quality-page .repository-quality-table,
.institutions-admin-page .institution-repositories-table {
  table-layout: fixed !important;
}
.repository-quality-page .repository-quality-table {
  min-width: 920px !important;
}
.repository-quality-page .repository-quality-table th:nth-child(1),
.repository-quality-page .repository-quality-table td:nth-child(1) {
  width: 120px !important;
}
.repository-quality-page .repository-quality-table th:nth-child(4),
.repository-quality-page .repository-quality-table td:nth-child(4),
.repository-quality-page .repository-quality-table th:nth-child(5),
.repository-quality-page .repository-quality-table td:nth-child(5) {
  width: 112px !important;
  text-align: center !important;
}
.repository-quality-page .repository-quality-table th:last-child,
.repository-quality-page .repository-quality-table td:last-child {
  width: 94px !important;
}
.repository-quality-page .repository-quality-table td,
.institutions-admin-page .institution-repositories-table td {
  overflow-wrap: anywhere !important;
}
.institutions-admin-page .institution-repositories-table th:nth-child(1),
.institutions-admin-page .institution-repositories-table td:nth-child(1) {
  width: 30% !important;
}
.institutions-admin-page .institution-repositories-table th:last-child,
.institutions-admin-page .institution-repositories-table td:last-child {
  width: 190px !important;
}
@media (max-width: 760px) {
  .repository-suite-page .suite-stats,
  .record-quality-page .record-quality-stats {
    grid-template-columns: 1fr !important;
  }
  .repository-suite-page .stat-card,
  .record-quality-page .stat-card {
    min-height: 0 !important;
  }
  .repository-quality-page .repository-quality-table,
  .institutions-admin-page .institution-repositories-table {
    min-width: 0 !important;
    table-layout: auto !important;
  }
}

/* Gap closure: repository search chips, verification panels, compact review actions */
.repo-mobile-filter-toggle{display:none;margin-bottom:12px}.repo-filter-chips{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}.repo-filter-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #d8dee4;background:#fff;border-radius:var(--inrep-radius, 10px) !important;padding:7px 11px;text-decoration:none;font-size:12px;font-weight:700;color:#334155}.repo-filter-chip b{font-size:15px;line-height:1}.repo-filter-chip.clear{background:#f8fafc;color:#64748b}.verification-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;margin:18px 0}.verification-panel,.citation-card{border:1px solid #e5e7eb;border-radius:var(--inrep-radius, 10px) !important;background:#fff;padding:14px}.metadata-grid.compact{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.qr-placeholder{text-align:center}.qr-box{width:104px;height:104px;margin:8px auto;border:1px dashed #94a3b8;border-radius:var(--inrep-radius, 10px) !important;display:grid;place-items:center;font-weight:900;color:#64748b;background:#f8fafc}.citation-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.citation-card code{display:block;white-space:pre-wrap;overflow-wrap:anywhere;margin:8px 0;font-size:12px}.record-card-top{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.inline-upload-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-upload-form input[type=file]{max-width:230px}.review-more-actions{position:relative}.review-more-actions summary{list-style:none;cursor:pointer}.review-more-actions summary::-webkit-details-marker{display:none}.review-more-actions[open]{padding:8px;border:1px solid #e5e7eb;border-radius:var(--inrep-radius, 10px) !important;background:#fff}.text-warning{color:#92400e;font-weight:700}@media(max-width:820px){.repo-mobile-filter-toggle{display:inline-flex}.repo-filter-wrap-v3{display:none}.repo-filter-wrap-v3.is-open{display:block}.verification-grid{grid-template-columns:1fr}.review-action-stack{align-items:stretch}.review-action-stack .btn,.review-action-stack button{width:100%}.inline-upload-form{width:100%}.inline-upload-form input[type=file]{max-width:100%;width:100%}}

/* Gap-closure review/submission hardening */
.duplicate-warning-card[hidden]{display:none!important}
.duplicate-warning-card{border-left:4px solid var(--color-amber,#f59e0b)}
.duplicate-warning-results{display:grid;gap:8px;margin:10px 0}
.duplicate-warning-item{display:grid;gap:4px;padding:10px;border:1px solid var(--border,#e5e7eb);border-radius:var(--inrep-radius, 10px) !important;background:var(--surface-muted,#f8fafc)}
.duplicate-warning-item span{font-size:.85rem;color:var(--muted,#64748b)}
.admin-filter-bar select,.admin-filter-bar input{min-height:38px}
.review-action-stack details{position:relative}
.review-action-stack details[open] summary{margin-bottom:6px}
@media (max-width: 760px){
  .submission-checklist-row{grid-template-columns:1fr!important}
  .duplicate-warning-item{font-size:.92rem}
  .admin-filter-bar{grid-template-columns:1fr!important}
}

/* 2026-05-19: repository admin design repair from visual QA screenshots */
.repository-suite-page,
.record-quality-page,
.repository-quality-page,
.institutions-admin-page {
  max-width: min(100%, var(--admin-content-max, 1280px)) !important;
  overflow-x: clip !important;
}

.repository-suite-page .suite-stats,
.record-quality-page .record-quality-stats {
  display: grid !important;
  align-items: stretch !important;
  gap: clamp(16px, 2.2vw, 24px) !important;
}

.repository-suite-page .stat-card,
.record-quality-page .stat-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: flex-start !important;
  gap: 10px !important;
  min-height: 128px !important;
  padding: 22px 24px !important;
  overflow: hidden !important;
  text-align: left !important;
}

.repository-suite-page .stat-card-metric,
.record-quality-page .stat-card-metric {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 6px !important;
  width: 100% !important;
  min-width: 0 !important;
}

.repository-suite-page .stat-card-metric span,
.record-quality-page .stat-card-metric span {
  display: block !important;
  margin: 0 !important;
  color: #17251e !important;
  font-size: 15px !important;
  font-weight: 650 !important;
  letter-spacing: -.01em !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
  text-transform: none !important;
}

.repository-suite-page .stat-card-metric strong,
.record-quality-page .stat-card-metric strong {
  display: block !important;
  margin: 0 !important;
  color: #07170f !important;
  font-size: clamp(28px, 2.8vw, 38px) !important;
  font-weight: 850 !important;
  letter-spacing: -.045em !important;
  line-height: .95 !important;
  overflow-wrap: anywhere !important;
}

.repository-suite-page .stat-card > small,
.record-quality-page .stat-card > small {
  display: block !important;
  margin: 0 !important;
  color: #4a5f54 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
  max-width: 34ch !important;
}

.record-quality-page .stat-card a {
  color: #0f8a3d !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.record-quality-page .stat-card a:hover,
.institutions-admin-page .table-route-link:hover {
  text-decoration: underline !important;
}

.institutions-admin-page .admin-panel {
  overflow: hidden !important;
}

.institutions-admin-page .institution-repositories-table {
  table-layout: fixed !important;
  min-width: 980px !important;
}

.institutions-admin-page .institution-repositories-table th:nth-child(1),
.institutions-admin-page .institution-repositories-table td:nth-child(1) { width: 31% !important; }
.institutions-admin-page .institution-repositories-table th:nth-child(2),
.institutions-admin-page .institution-repositories-table td:nth-child(2) { width: 18% !important; }
.institutions-admin-page .institution-repositories-table th:nth-child(3),
.institutions-admin-page .institution-repositories-table td:nth-child(3) { width: 21% !important; }
.institutions-admin-page .institution-repositories-table th:nth-child(4),
.institutions-admin-page .institution-repositories-table td:nth-child(4) { width: 12% !important; }
.institutions-admin-page .institution-repositories-table th:nth-child(5),
.institutions-admin-page .institution-repositories-table td:nth-child(5) { width: 18% !important; }

.institutions-admin-page .institution-repositories-table td {
  vertical-align: middle !important;
  overflow-wrap: anywhere !important;
}

.institutions-admin-page .table-meta-line,
.institutions-admin-page .table-route-link {
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}

.institutions-admin-page .institution-repositories-table .table-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

.repository-quality-page .table-responsive[data-mobile-card="1"] {
  max-width: 100% !important;
  overflow-x: auto !important;
  border-radius: var(--inrep-radius, 10px) !important;
}

.repository-quality-page .repository-quality-table {
  width: 100% !important;
  min-width: 980px !important;
  table-layout: fixed !important;
}

.repository-quality-page .repository-quality-table th:nth-child(1),
.repository-quality-page .repository-quality-table td:nth-child(1) { width: 120px !important; }
.repository-quality-page .repository-quality-table th:nth-child(2),
.repository-quality-page .repository-quality-table td:nth-child(2) { width: 30% !important; }
.repository-quality-page .repository-quality-table th:nth-child(3),
.repository-quality-page .repository-quality-table td:nth-child(3) { width: 24% !important; }
.repository-quality-page .repository-quality-table th:nth-child(4),
.repository-quality-page .repository-quality-table td:nth-child(4),
.repository-quality-page .repository-quality-table th:nth-child(5),
.repository-quality-page .repository-quality-table td:nth-child(5) { width: 110px !important; text-align: center !important; }
.repository-quality-page .repository-quality-table th:nth-child(6),
.repository-quality-page .repository-quality-table td:nth-child(6) { width: 120px !important; }
.repository-quality-page .repository-quality-table th:nth-child(7),
.repository-quality-page .repository-quality-table td:nth-child(7) { width: 98px !important; text-align: right !important; }

.repository-quality-page .score-pill {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 58px !important;
  min-height: 32px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 6px 11px !important;
  line-height: 1 !important;
}

@media (max-width: 1023px) {
  .repository-suite-page .suite-stats,
  .record-quality-page .record-quality-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"],
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] {
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] table,
  .repository-quality-page .table-responsive[data-mobile-card="1"] thead,
  .repository-quality-page .table-responsive[data-mobile-card="1"] tbody,
  .repository-quality-page .table-responsive[data-mobile-card="1"] tr,
  .repository-quality-page .table-responsive[data-mobile-card="1"] th,
  .repository-quality-page .table-responsive[data-mobile-card="1"] td,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] table,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] thead,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] tbody,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] tr,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] th,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] table,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] table {
    background: transparent !important;
    border: 0 !important;
    table-layout: auto !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] thead,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] thead {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] tbody,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] tbody {
    display: grid !important;
    gap: 14px !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] tr,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] tr {
    padding: 14px !important;
    border: 1px solid #dce7df !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff !important;
    box-shadow: 0 12px 30px rgba(10, 31, 21, .06) !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td {
    display: grid !important;
    grid-template-columns: minmax(104px, 36%) minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: start !important;
    padding: 10px 0 !important;
    border: 0 !important;
    border-bottom: 1px solid #eef4f0 !important;
    background: transparent !important;
    text-align: left !important;
    overflow-wrap: anywhere !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td:last-child,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td:last-child {
    border-bottom: 0 !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td::before,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td::before {
    content: attr(data-label) !important;
    color: #64756a !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .055em !important;
    line-height: 1.35 !important;
    text-transform: uppercase !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td[data-label=""],
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td[data-label=""] {
    grid-template-columns: 1fr !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td[data-label=""]::before,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td[data-label=""]::before {
    display: none !important;
  }

  .repository-quality-page .score-pill {
    min-width: 64px !important;
  }
}

@media (max-width: 640px) {
  .repository-suite-page .suite-stats,
  .record-quality-page .record-quality-stats {
    grid-template-columns: 1fr !important;
  }

  .repository-suite-page .stat-card,
  .record-quality-page .stat-card {
    min-height: 0 !important;
    padding: 18px !important;
  }

  .repository-suite-page .stat-card-metric strong,
  .record-quality-page .stat-card-metric strong {
    font-size: 30px !important;
  }

  .repository-quality-page .table-responsive[data-mobile-card="1"] td,
  .institutions-admin-page .admin-table-wrap[data-mobile-card="1"] td {
    grid-template-columns: 1fr !important;
    gap: 5px !important;
  }

  .institutions-admin-page .institution-repositories-table .table-actions .btn,
  .repository-quality-page .repository-quality-table .btn {
    width: 100% !important;
    justify-content: center !important;
  }
}


/* Signup autosave + password usability hardening */
.signup-autosave-status {
  margin: 0 0 4px !important;
  padding: 10px 12px !important;
  border: 1px solid #d7eadf !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f6fbf8 !important;
  color: #32533e !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
}
.register-center .password-control,
.guest-register-form .password-control,
.password-control {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
}
.register-center .password-control input,
.guest-register-form .password-control input,
.password-control input {
  min-width: 0 !important;
  width: 100% !important;
  padding-right: 14px !important;
}
.register-center .password-control .password-toggle,
.guest-register-form .password-control .password-toggle,
.password-control .password-toggle {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  min-width: 76px !important;
  min-height: 46px !important;
  padding: 0 14px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0f172a !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: none !important;
}
.register-center .password-control .password-toggle:hover,
.guest-register-form .password-control .password-toggle:hover,
.password-control .password-toggle:hover {
  border-color: #98a2b3 !important;
  background: #f8fafc !important;
}
.register-center .password-help,
.guest-register-form .password-help,
.password-help,
.password-match-help {
  display: block !important;
  margin-top: 6px !important;
  color: #5f6f67 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
}
.register-center .password-help.error,
.guest-register-form .password-help.error,
.password-help.error,
.password-match-help.error { color: #b42318 !important; }
.register-center .password-help.ok,
.guest-register-form .password-help.ok,
.password-help.ok,
.password-match-help.ok { color: #087a3d !important; }
.register-center .password-checklist,
.guest-register-form .password-checklist,
.password-checklist {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding: 10px !important;
  margin-top: 8px !important;
  border: 1px solid #e4ece7 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf9 !important;
  list-style: none !important;
}
.register-center .password-checklist li,
.guest-register-form .password-checklist li,
.password-checklist li {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 5px 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #475467 !important;
  font-size: 12.5px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}
.register-center .password-checklist li::before,
.guest-register-form .password-checklist li::before,
.password-checklist li::before {
  content: '\00D7' !important;
  display: inline-grid !important;
  place-items: center !important;
  width: 17px !important;
  height: 17px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff4e5 !important;
  color: #b42318 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  flex: 0 0 17px !important;
}
.register-center .password-checklist li.passed,
.guest-register-form .password-checklist li.passed,
.password-checklist li.passed {
  color: #087a3d !important;
  background: #f0fdf4 !important;
}
.register-center .password-checklist li.passed::before,
.guest-register-form .password-checklist li.passed::before,
.password-checklist li.passed::before {
  content: '\2713' !important;
  background: #dff8e8 !important;
  color: #087a3d !important;
}
.register-center label.is-invalid .password-control input,
.guest-register-form label.is-invalid .password-control input {
  border-color: #d92d20 !important;
  box-shadow: 0 0 0 3px rgba(217,45,32,.10) !important;
}
@media (max-width: 560px) {
  .register-center .password-control,
  .guest-register-form .password-control,
  .password-control { grid-template-columns: 1fr !important; }
  .register-center .password-control .password-toggle,
  .guest-register-form .password-control .password-toggle,
  .password-control .password-toggle { width: 100% !important; }
  .register-center .password-checklist,
  .guest-register-form .password-checklist,
  .password-checklist { display: grid !important; grid-template-columns: 1fr !important; }
}

/* Workflow dashboard cards: action center + onboarding checklist */
.workflow-action-center,
.workflow-onboarding {
  margin: 28px 0;
  padding: clamp(18px, 2.4vw, 28px);
  border: 1px solid #dfe8e2;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.84);
  box-shadow: 0 24px 70px rgba(15, 23, 42, .06);
}
.workflow-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.workflow-kicker {
  display: block;
  margin-bottom: 4px;
  color: #6c7b72;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.workflow-section-head h2 {
  margin: 0;
  color: #0d1511;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.08;
  letter-spacing: -.035em;
}
.workflow-progress-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  border: 1px solid #dce7e0;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f6faf7;
  color: #24342b;
  font-size: 14px;
  font-weight: 800;
  white-space: nowrap;
}
.workflow-action-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.workflow-action-card,
.workflow-check-item {
  min-width: 0;
  color: inherit;
  text-decoration: none;
}
.workflow-action-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  min-height: 96px;
  padding: 16px;
  border: 1px solid #e2ebe5;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .045);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.workflow-action-card:hover,
.workflow-check-item:hover {
  transform: translateY(-1px);
  border-color: #b8d9c4;
  box-shadow: 0 18px 42px rgba(15, 23, 42, .07);
}
.workflow-state-dot {
  width: 12px;
  height: 12px;
  margin-top: 6px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #98a2b3;
  box-shadow: 0 0 0 5px rgba(152,162,179,.12);
}
.workflow-action-card strong,
.workflow-check-item strong {
  display: block;
  color: #101828;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.workflow-action-card small {
  display: block;
  margin-top: 6px;
  color: #5f6f67;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.workflow-action-card em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f2f4f7;
  color: #101828;
  font-size: 13px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}
.workflow-state-needs_attention .workflow-state-dot { background: #dc6803; box-shadow: 0 0 0 5px rgba(220,104,3,.12); }
.workflow-state-pending .workflow-state-dot { background: #1570ef; box-shadow: 0 0 0 5px rgba(21,112,239,.12); }
.workflow-state-done .workflow-state-dot { background: #12b76a; box-shadow: 0 0 0 5px rgba(18,183,106,.13); }
.workflow-state-info .workflow-state-dot { background: #7a5af8; box-shadow: 0 0 0 5px rgba(122,90,248,.12); }
.workflow-state-needs_attention em { background: #fff4e5; color: #b54708; }
.workflow-state-pending em { background: #eff8ff; color: #175cd3; }
.workflow-state-done em { background: #ecfdf3; color: #067647; }
.workflow-checklist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 12px;
}
.workflow-check-item {
  display: grid;
  gap: 8px;
  padding: 15px;
  border: 1px solid #e3ece6;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff;
  box-shadow: 0 12px 34px rgba(15, 23, 42, .04);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.workflow-check-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  padding: 5px 10px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f2f4f7;
  color: #344054;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.workflow-check-item.workflow-state-done .workflow-check-status { background: #ecfdf3; color: #067647; }
.workflow-check-item.workflow-state-pending .workflow-check-status { background: #eff8ff; color: #175cd3; }
.workflow-check-item.workflow-state-needs_attention .workflow-check-status { background: #fff4e5; color: #b54708; }
.verify-email-resend-form {
  display: grid;
  gap: 12px;
  text-align: center;
}
.verify-resend-prompt {
  margin: 0;
  color: #5f6f67;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}
@media (max-width: 720px) {
  .workflow-section-head {
    align-items: stretch;
    flex-direction: column;
  }
  .workflow-progress-count {
    width: fit-content;
  }
  .workflow-action-grid,
  .workflow-checklist {
    grid-template-columns: 1fr;
  }
  .workflow-action-card {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .workflow-action-card em {
    grid-column: 2;
    justify-self: start;
  }
}

/* Final hotfix: registration password controls + compact submission link layout */
.student-register-wizard .password-control,
.signup-form-grid .password-control,
.register-center .password-control {
  display: flex !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
}
.student-register-wizard .password-control input,
.signup-form-grid .password-control input,
.register-center .password-control input {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: auto !important;
  padding-right: 14px !important;
}
.student-register-wizard .password-control .password-toggle,
.signup-form-grid .password-control .password-toggle,
.register-center .password-control .password-toggle {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  flex: 0 0 76px !important;
  width: 76px !important;
  min-width: 76px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
.student-register-wizard label.is-invalid .password-control input,
.register-center label.is-invalid .password-control input {
  border-color: #d92d20 !important;
  box-shadow: 0 0 0 3px rgba(217,45,32,.10) !important;
}
.submission-primary-card {
  gap: 16px !important;
  align-content: start !important;
}
.submission-primary-card .card-heading-row {
  min-height: 0 !important;
  margin: 0 !important;
  padding-bottom: 12px !important;
}
.submission-primary-card .submission-url-box {
  margin-top: 0 !important;
  gap: 10px !important;
}
.submission-primary-card .submission-share-grid {
  margin-top: 0 !important;
}

/* Hotfix: keep desktop dashboard navigation readable and expandable. */
:root{--admin-sidebar-width-expanded:280px;}
@media (min-width:1024px){
  body:not(.admin-sidebar-collapsed) .admin-sidebar-link span:not(.admin-count-badge):not(.admin-sidebar-pin){
    white-space:normal!important;
    line-height:1.25!important;
    overflow:visible!important;
    text-overflow:clip!important;
  }
  body.admin-sidebar-collapsed .admin-sidebar:hover{width:280px!important;box-shadow:0 24px 60px rgba(0,0,0,.22);z-index:40;}
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-brand span:not(.inrep-mark),
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-label,
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-link span:not(.admin-count-badge),
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-pin{display:inline-flex!important;}
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-link{width:100%!important;justify-content:flex-start!important;padding:10px 12px!important;}
  body.admin-sidebar-collapsed .admin-sidebar:hover .admin-sidebar-label{display:flex!important;}
}

/* Submission PDF preview hotfix: keep preview usable when browser blocks inline PDFs. */
.pdf-preview-box .pdf-preview-selected{font-weight:700;margin-bottom:.75rem;color:#10231b}
.pdf-preview-box .pdf-preview-object{display:block;width:100%;height:min(68vh,620px);border:0;border-radius:var(--inrep-radius, 10px) !important;background:#f1f5f9}
.pdf-preview-box .pdf-preview-fallback{display:grid;place-items:center;gap:12px;min-height:260px;padding:24px;text-align:center;color:#475569;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:var(--inrep-radius, 10px) !important}

/* Public institution customizer cross-check patch */
[data-setup-panel][hidden] { display: none !important; }
.setup-tabs { position: sticky; top: 72px; z-index: 12; background: rgba(247,251,248,.96); backdrop-filter: blur(12px); border-radius: var(--inrep-radius, 10px) !important; padding: 10px !important; border: 1px solid var(--border-light,#dfe7df) !important; box-shadow: 0 12px 32px rgba(15,23,42,.05); }
.setup-tab { transition: transform .16s ease, background .16s ease, color .16s ease, border-color .16s ease, box-shadow .16s ease; }
.setup-tab:hover { transform: translateY(-1px); border-color: var(--primary,#1db954); box-shadow: 0 10px 24px rgba(15,23,42,.06); }
.setup-tab.active, .setup-tab[aria-selected="true"] { box-shadow: 0 12px 28px rgba(29,185,84,.18); }
.customizer-grid .admin-panel { align-self: start; }
.customizer-grid input[type="color"] { min-height: 44px; padding: 5px; }
.customizer-grid input[type="range"] { min-height: 36px; accent-color: var(--primary,#1db954); }
.tenant-public-page .tenant-mkt-nav { background: var(--tenant-nav-bg,#fff) !important; border-bottom-color: color-mix(in srgb,var(--tenant-nav-bg,#fff) 75%,#000 10%) !important; color: var(--tenant-nav-text,#0f172a) !important; }
.tenant-public-page .tenant-mkt-nav .mkt-nav-logo, .tenant-public-page .tenant-mkt-nav .mkt-nav-logo span { color: var(--tenant-nav-text,#0f172a) !important; font-size: var(--tenant-nav-font-size,14px) !important; }
.tenant-public-page .tenant-mkt-nav .mkt-nav-item, .tenant-public-page .tenant-mkt-nav .tenant-nav-items a { color: var(--tenant-nav-link,#334155) !important; font-size: var(--tenant-nav-font-size,14px) !important; font-weight: 650 !important; }
.tenant-public-page .tenant-mkt-nav .mkt-nav-item:hover, .tenant-public-page .tenant-mkt-nav .tenant-nav-items a:hover { background: color-mix(in srgb,var(--tenant-primary,#1db954) 10%,transparent) !important; color: var(--tenant-nav-text,#0f172a) !important; }
.tenant-public-page .mkt-nav-search { background: color-mix(in srgb,var(--tenant-nav-bg,#fff) 85%,#fff 15%) !important; border-color: color-mix(in srgb,var(--tenant-nav-link,#334155) 18%,transparent) !important; }
.tenant-public-page .tenant-footer { background: var(--tenant-footer-bg,#07140d) !important; color: var(--tenant-footer-text,#e5f5ea) !important; }
.tenant-public-page .tenant-footer .mkt-footer-tagline, .tenant-public-page .tenant-footer a, .tenant-public-page .tenant-footer li, .tenant-public-page .tenant-footer p, .tenant-public-page .tenant-footer h3 { color: var(--tenant-footer-text,#e5f5ea) !important; }
.tenant-nav-logo-img,.tenant-footer-logo-img{display:inline-block;width:42px;height:42px;object-fit:contain;border-radius:var(--inrep-radius, 10px) !important;background:#fff;border:1px solid rgba(15,23,42,.08);}
.institution-page .institution-hero { isolation: isolate; display:flex!important; align-items:center!important; justify-content:center!important; padding-inline: clamp(18px,5vw,60px) !important; background-color:#f8fcf9!important; }
.institution-page .institution-hero::before, .institution-page .institution-hero::after { display:none!important; content:none!important; }
.institution-hero-inner { position:relative; z-index:2; width:min(1180px,100%); margin-inline:auto; display:grid; gap: clamp(22px,4vw,42px); justify-items:center; text-align: inherit; }
.institution-hero-copy { display:grid; justify-items:inherit; gap: 14px; max-width: 980px; }
.institution-public-logo { width:min(112px,28vw); height:auto; max-height:112px; object-fit:contain; border-radius:var(--inrep-radius, 10px) !important; padding:10px; background:rgba(255,255,255,.9); box-shadow:0 18px 52px rgba(15,23,42,.14); }
.institution-hero-search-card { width:min(880px,100%); display:grid; gap:14px; justify-items:center; }
.institution-page .institution-hero .hero-h1, .institution-page .institution-hero .hero-subtitle { max-width: 980px !important; margin-left: auto !important; margin-right: auto !important; }
.institution-page .institution-hero .hero-subtitle { line-height:1.6!important; }
.institution-hero-left .institution-hero-inner, .institution-hero-left .institution-hero-copy { justify-items:start; text-align:left; }
.institution-hero-right .institution-hero-inner, .institution-hero-right .institution-hero-copy { justify-items:end; text-align:right; }
.institution-hero-split .institution-hero { display:flex!important; }
.institution-hero-split .institution-hero-inner { grid-template-columns: minmax(0,1.04fr) minmax(300px,.72fr); align-items:center; justify-items:stretch; text-align:left; }
.institution-hero-split .institution-hero-copy { justify-items:start; text-align:left; }
.institution-hero-split .institution-hero-search-card { justify-self:end; padding:22px; border-radius:var(--inrep-radius, 10px) !important; background:rgba(255,255,255,.92); border:1px solid rgba(255,255,255,.72); box-shadow:0 28px 90px rgba(15,23,42,.18); backdrop-filter: blur(12px); }
.institution-hero-split .institution-hero-search-card .hero-actions { justify-content:stretch!important; }
.institution-hero-split .institution-hero-search-card .hero-actions a { flex:1 1 180px; justify-content:center; color:#0f172a!important; border-color:rgba(15,23,42,.12)!important; background:#fff!important; }
.institution-template-classic .institution-rich-card, .institution-template-classic .project-public-card, .institution-template-classic .audience-card { border-radius:var(--inrep-radius, 10px) !important; }
.institution-template-modern .institution-rich-card,.institution-template-modern .project-public-card,.institution-template-modern .audience-card{border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 24px 70px rgba(15,23,42,.08)!important;}
.institution-template-editorial .institution-hero .institution-hero-inner{justify-items:start;text-align:left;}
.institution-template-editorial .institution-hero .hero-search{margin-left:0!important;margin-right:auto!important;}
.institution-template-visual .institution-hero{min-height:max(var(--inst-hero-height,560px),620px)!important;}
.institution-template-premium .institution-hero{border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 30px 80px rgba(15,23,42,.14);}
.institution-template-premium .institution-rich-card,.institution-template-premium .institution-contact-card,.institution-template-premium .institution-quick-grid a{border-radius:var(--inrep-radius, 10px) !important;box-shadow:0 24px 70px rgba(15,23,42,.09);}
.institution-template-minimal .institution-hero{min-height:420px!important;border-bottom:1px solid #e6eee8;}
.institution-template-minimal .institution-rich-overview,.institution-template-minimal .institution-guidance-section{display:none!important;}
.institution-about-copy { color: var(--text-muted-dark,#5f6f64); line-height:1.7; }
@media (max-width: 900px){
  .institution-hero-split .institution-hero-inner { grid-template-columns:1fr; text-align:center; }
  .institution-hero-split .institution-hero-copy { justify-items:center; text-align:center; }
  .institution-hero-split .institution-hero-search-card { justify-self:center; width:100%; }
  .tenant-public-page .tenant-nav-items { display:none!important; }
}
@media (max-width: 640px){
  .setup-tabs { top: 58px; overflow-x:auto; flex-wrap:nowrap; justify-content:flex-start; }
  .setup-tab { flex:0 0 auto; }
  .institution-page .institution-hero { padding-inline: 16px !important; }
  .institution-public-logo { width:86px; max-height:86px; border-radius:var(--inrep-radius, 10px) !important; }
  .institution-hero-search-card { width:100%; }
}

/* Patch: dashboard metric spacing and viewer/notification polish */
.compact-stats .stat-card,
.admin-grid .admin-panel.stat-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.stat-card .stat-card-metric {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.stat-card .stat-card-metric span,
.compact-stats .stat-card > span,
.admin-grid .admin-panel.stat-card > span {
  line-height: 1.35;
}
.stat-card .stat-card-metric strong,
.compact-stats .stat-card > strong,
.admin-grid .admin-panel.stat-card > strong {
  flex-shrink: 0;
  margin-left: 8px;
}
.notif-item {
  gap: 14px;
}
.notif-actions .btn.tiny {
  white-space: nowrap;
}
@media (max-width: 760px) {
  .compact-stats .stat-card,
  .admin-grid .admin-panel.stat-card,
  .stat-card .stat-card-metric {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
  .stat-card .stat-card-metric strong,
  .compact-stats .stat-card > strong,
  .admin-grid .admin-panel.stat-card > strong {
    margin-left: 0;
  }
}

/* Production stabilization: auth scrolling, password peek controls, and retry countdowns */
.auth-body {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  min-height: 100dvh !important;
  align-items: start !important;
  justify-items: center !important;
  padding: clamp(18px, 4vw, 48px) 18px !important;
}
.auth-wrapper {
  width: 100% !important;
  min-height: calc(100dvh - clamp(36px, 8vw, 96px)) !important;
  padding: 0 !important;
}
.auth-center,
.auth-card--inrep,
.auth-wrapper .auth-card,
.forgot-password-card {
  max-width: calc(100vw - 36px) !important;
}
.auth-center > .auth-card {
  width: 100% !important;
  box-shadow: none !important;
  border: 1px solid var(--border-light) !important;
  padding: clamp(20px, 4vw, 28px) !important;
}
.auth-form,
.public-form,
.forgot-password-form,
.supervisor-register-form,
.form-grid {
  min-width: 0 !important;
}
.auth-field,
.auth-form .form-group,
.form-grid label,
.supervisor-register-form label {
  min-width: 0 !important;
}
.password-wrap {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}
.password-wrap input {
  width: 100% !important;
  min-width: 0 !important;
  padding-right: 88px !important;
}
.password-wrap .password-toggle,
.password-wrap [data-password-toggle] {
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  min-width: 68px !important;
  width: auto !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid #cbd5e1 !important;
  background: #f8fafc !important;
  color: #334155 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
.password-control {
  display: flex !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
  min-width: 0 !important;
}
.password-control input {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  padding-right: 14px !important;
}
.password-control .password-toggle,
.password-control [data-password-toggle],
.password-control [data-toggle-pass] {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  flex: 0 0 76px !important;
  min-width: 76px !important;
  min-height: 46px !important;
  padding: 0 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  white-space: nowrap !important;
}
[data-rate-limit-countdown="1"],
.admin-alert.error[data-rate-limit-countdown="1"],
.alert.error[data-rate-limit-countdown="1"],
.install-alert.error[data-rate-limit-countdown="1"] {
  border-left: 4px solid #f59e0b !important;
}
@media (max-width: 640px) {
  .auth-body {
    padding: 14px !important;
  }
  .auth-center,
  .auth-card--inrep,
  .auth-wrapper .auth-card,
  .forgot-password-card {
    width: min(100%, calc(100vw - 28px)) !important;
    padding: 24px 20px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .password-control {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  .password-control .password-toggle,
  .password-control [data-password-toggle],
  .password-control [data-toggle-pass] {
    width: 100% !important;
    flex-basis: auto !important;
  }
}

/* Production stabilization: dashboard topbar notification alignment */
.admin-topbar-actions {
  align-items: center !important;
  min-width: 0 !important;
}
.admin-notification-menu {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
}
.admin-notification-bell.admin-icon-btn {
  position: relative !important;
  width: 38px !important;
  min-width: 38px !important;
  height: 38px !important;
  padding: 0 !important;
  overflow: visible !important;
}
.admin-notification-bell .admin-count-badge {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  transform: none !important;
  z-index: 3 !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 5px !important;
  display: inline-grid !important;
  place-items: center !important;
  line-height: 1 !important;
  pointer-events: none !important;
}
.admin-notification-bell .admin-count-badge[hidden] {
  display: none !important;
}
.admin-notification-popover {
  position: absolute !important;
  top: calc(100% + 10px) !important;
  right: 0 !important;
  left: auto !important;
  width: min(360px, calc(100vw - 24px)) !important;
  max-height: min(460px, calc(100vh - 92px)) !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) !important;
  overflow: hidden !important;
  border: 1px solid var(--border-light, #e5e7eb) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark, #0f172a) !important;
  box-shadow: 0 18px 48px rgba(15, 23, 42, .16) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(8px) !important;
  pointer-events: none !important;
  z-index: 260 !important;
}
.admin-notification-menu:hover .admin-notification-popover,
.admin-notification-menu:focus-within .admin-notification-popover,
.admin-notification-menu.is-open .admin-notification-popover {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  pointer-events: auto !important;
}
.admin-notification-popover header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--border-light, #e5e7eb) !important;
}
.admin-notification-popover header strong {
  margin: 0 !important;
  font-size: 14px !important;
  color: var(--text-dark, #0f172a) !important;
}
.admin-notification-popover header a {
  font-size: 12px !important;
  font-weight: 800 !important;
  color: var(--primary, #16a34a) !important;
  white-space: nowrap !important;
}
.admin-notification-list {
  min-height: 0 !important;
  overflow: auto !important;
  display: grid !important;
  align-content: start !important;
}
.admin-notification-empty {
  padding: 16px !important;
  color: var(--text-muted-dark, #64748b) !important;
  font-size: 13px !important;
}
.admin-notification-preview {
  display: grid !important;
  grid-template-columns: 8px minmax(0, 1fr) !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--border-light, #e5e7eb) !important;
  color: inherit !important;
  text-decoration: none !important;
}
.admin-notification-preview:hover {
  background: var(--bg-light, #f8fafc) !important;
  color: inherit !important;
}
.admin-notification-preview-dot {
  width: 8px !important;
  height: 8px !important;
  margin-top: 6px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary, #16a34a) !important;
}
.admin-notification-preview-body {
  min-width: 0 !important;
  display: grid !important;
  gap: 3px !important;
}
.admin-notification-preview-body strong,
.admin-notification-preview-body small,
.admin-notification-preview-body em {
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
}
.admin-notification-preview-body strong {
  color: var(--text-dark, #0f172a) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}
.admin-notification-preview-body small,
.admin-notification-preview-body em {
  color: var(--text-muted-dark, #64748b) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-style: normal !important;
}
@media (max-width: 700px) {
  .admin-notification-popover {
    position: fixed !important;
    top: 62px !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-height: min(420px, calc(100vh - 86px)) !important;
  }
}

/* Supervisor review queue: scoped layout repair */
.supervisor-queue-page .supervisor-review-panel {
  padding: clamp(16px, 2vw, 24px) !important;
  overflow: visible !important;
}
.supervisor-review-list {
  display: grid !important;
  gap: 18px !important;
}
.supervisor-review-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px) !important;
  gap: clamp(18px, 2.5vw, 28px) !important;
  align-items: start !important;
  padding: clamp(18px, 2.4vw, 26px) !important;
  border: 1px solid rgba(148, 163, 184, .24) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .07) !important;
}
.supervisor-review-main {
  min-width: 0 !important;
  display: grid !important;
  gap: 14px !important;
}
.supervisor-review-kicker {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  color: var(--text-muted-dark, #64748b) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
.supervisor-review-card h2 {
  margin: 0 !important;
  max-width: 100% !important;
  color: var(--text-dark, #0f172a) !important;
  font-size: clamp(18px, 2.1vw, 24px) !important;
  line-height: 1.25 !important;
  letter-spacing: -.02em !important;
  overflow-wrap: anywhere !important;
}
.supervisor-review-meta {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
}
.supervisor-review-meta > div {
  min-width: 0 !important;
  padding: 12px 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(248, 250, 252, .9) !important;
  border: 1px solid rgba(226, 232, 240, .8) !important;
}
.supervisor-review-meta dt {
  margin: 0 0 4px !important;
  color: var(--text-muted-dark, #64748b) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}
.supervisor-review-meta dd {
  margin: 0 !important;
  color: var(--text-dark, #0f172a) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
}
.supervisor-review-meta .muted {
  margin-top: 3px !important;
  color: var(--text-muted-dark, #64748b) !important;
  font-weight: 600 !important;
}
.supervisor-review-abstract {
  margin: 0 !important;
  padding: 14px 16px !important;
  border-left: 3px solid var(--primary, #16a34a) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(240, 253, 244, .75) !important;
  color: var(--text-dark, #334155) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  overflow-wrap: anywhere !important;
}
.supervisor-review-links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.supervisor-review-actions {
  display: grid !important;
  gap: 12px !important;
  min-width: 0 !important;
  width: 100% !important;
}
.supervisor-review-actions form {
  display: grid !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 14px !important;
  border: 1px solid rgba(226, 232, 240, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(248, 250, 252, .85) !important;
}
.supervisor-review-actions label,
.supervisor-review-actions label span {
  display: grid !important;
  gap: 7px !important;
  width: 100% !important;
  color: var(--text-dark, #0f172a) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}
.supervisor-review-actions textarea {
  width: 100% !important;
  min-height: 96px !important;
  resize: vertical !important;
  box-sizing: border-box !important;
  border: 1px solid rgba(148, 163, 184, .45) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  padding: 12px 13px !important;
  background: #fff !important;
  color: var(--text-dark, #0f172a) !important;
  font: inherit !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}
.supervisor-review-actions .btn,
.supervisor-review-links .btn {
  justify-content: center !important;
  min-height: 40px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  white-space: normal !important;
}
.supervisor-review-actions .btn {
  width: 100% !important;
}
@media (max-width: 980px) {
  .supervisor-review-card {
    grid-template-columns: 1fr !important;
  }
  .supervisor-review-actions {
    grid-template-columns: 1fr !important;
  }
  .supervisor-review-actions form {
    align-content: start !important;
  }
}
@media (max-width: 760px) {
  .supervisor-review-card {
    padding: 16px !important;
    border-radius: var(--inrep-radius, 10px) !important;
  }
  .supervisor-review-meta,
  .supervisor-review-actions {
    grid-template-columns: 1fr !important;
  }
  .supervisor-review-actions form {
    padding: 12px !important;
  }
  .supervisor-review-links .btn {
    width: 100% !important;
  }
}

/* UI repair pass: missing component styles and scoped layout guards */
.admin-page .admin-panel {
  overflow: visible !important;
}
.admin-page-header,
.admin-panel-header {
  min-width: 0 !important;
}
.admin-actions,
.form-actions,
.inline-actions,
.table-actions {
  min-width: 0 !important;
}
.admin-panel .btn,
.admin-page .btn,
.public-section .btn,
.project-detail .btn {
  align-items: center !important;
  display: inline-flex !important;
  gap: 8px !important;
  justify-content: center !important;
}
.admin-table-wrap {
  max-width: 100% !important;
}
.admin-panel input[type="checkbox"] {
  width: 18px !important;
  min-width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Librarian review queue */
.librarian-review-page .review-rules-panel {
  padding: clamp(18px, 2vw, 26px) !important;
}
.librarian-review-page .review-rules-panel .form-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(180px, 1fr)) !important;
  gap: 16px !important;
  align-items: end !important;
}
.librarian-review-page .review-rules-panel .inline-check {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 44px !important;
  margin: 0 !important;
}
.librarian-review-page .review-help-box {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
  margin-bottom: 16px !important;
}
.librarian-review-page .admin-filter-bar {
  display: grid !important;
  grid-template-columns: minmax(240px, 1.4fr) repeat(4, minmax(150px, 1fr)) auto auto !important;
  gap: 12px !important;
  align-items: end !important;
  padding: 16px !important;
  border: 1px solid rgba(224, 232, 226, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
  margin-bottom: 14px !important;
}
.librarian-review-page .admin-filter-bar label {
  margin: 0 !important;
  min-width: 0 !important;
}
.librarian-review-page #bulkActionPanel.table-bulk-bar {
  display: grid !important;
  grid-template-columns: max-content max-content minmax(150px, .7fr) max-content minmax(220px, 1fr) max-content max-content max-content !important;
  gap: 10px !important;
  align-items: center !important;
  width: 100% !important;
  margin: 14px 0 !important;
  padding: 14px !important;
  border: 1px solid rgba(224, 232, 226, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(135deg, #ffffff, #f6fbf7) !important;
  box-shadow: 0 12px 30px rgba(10, 31, 21, .05) !important;
}
.librarian-review-page #bulkActionPanel input {
  min-width: 0 !important;
  min-height: 38px !important;
}
.librarian-review-page .library-review-list {
  display: grid !important;
  gap: 14px !important;
  margin-top: 14px !important;
}
.librarian-review-page .library-review-select-all {
  display: inline-flex !important;
  width: fit-content !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(224, 232, 226, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark, #0a0a0a) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}
.librarian-review-page .library-review-card {
  display: grid !important;
  grid-template-columns: 24px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  padding: clamp(16px, 2vw, 22px) !important;
  border: 1px solid rgba(224, 232, 226, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 16px 42px rgba(10, 31, 21, .06) !important;
}
.librarian-review-page .library-review-check {
  display: flex !important;
  justify-content: center !important;
  padding-top: 4px !important;
}
.librarian-review-page .library-review-main {
  display: grid !important;
  gap: 14px !important;
  min-width: 0 !important;
}
.librarian-review-page .library-review-title-row {
  display: flex !important;
  justify-content: space-between !important;
  gap: 16px !important;
  align-items: flex-start !important;
  min-width: 0 !important;
}
.librarian-review-page .library-review-title-row > div:first-child {
  min-width: 0 !important;
}
.librarian-review-page .library-review-kicker {
  margin: 0 0 4px !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.librarian-review-page .library-review-title-row h3 {
  margin: 0 !important;
  max-width: 920px !important;
  color: var(--text-dark, #0a0a0a) !important;
  font-family: var(--font-display, Sora, sans-serif) !important;
  font-size: clamp(17px, 1.55vw, 22px) !important;
  line-height: 1.25 !important;
  letter-spacing: -.02em !important;
  overflow-wrap: anywhere !important;
}
.librarian-review-page .library-review-submeta {
  margin: 8px 0 0 !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
.librarian-review-page .library-review-primary-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}
.librarian-review-page .library-review-primary-actions form {
  display: inline-flex !important;
  margin: 0 !important;
}
.librarian-review-page .library-review-meta-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(150px, 1fr)) !important;
  gap: 10px !important;
}
.librarian-review-page .library-review-meta-item {
  min-width: 0 !important;
  display: grid !important;
  gap: 5px !important;
  align-content: start !important;
  padding: 12px !important;
  border: 1px solid rgba(224, 232, 226, .9) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf8 !important;
}
.librarian-review-page .library-review-meta-item > span:first-child {
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.librarian-review-page .library-review-meta-item strong {
  min-width: 0 !important;
  color: var(--text-dark, #0a0a0a) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
}
.librarian-review-page .library-review-meta-item small {
  min-width: 0 !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
}
.librarian-review-page .library-review-meta-item .inline-form {
  margin-top: 4px !important;
}
.librarian-review-page .library-review-secondary-actions {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(220px, 1fr)) auto !important;
  gap: 10px !important;
  align-items: start !important;
  padding-top: 4px !important;
}
.librarian-review-page .review-mini-form {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) max-content !important;
  gap: 8px !important;
  align-items: center !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.librarian-review-page .review-mini-form input {
  min-width: 0 !important;
  min-height: 38px !important;
}
.librarian-review-page .review-more-actions {
  min-width: 0 !important;
}
.librarian-review-page .review-more-actions summary.btn {
  width: 100% !important;
}
.librarian-review-page .review-more-actions[open] {
  padding: 10px !important;
  border: 1px solid rgba(224, 232, 226, .95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}
.librarian-review-page .library-review-more-panel {
  display: grid !important;
  gap: 10px !important;
  margin-top: 10px !important;
  min-width: min(420px, 100%) !important;
}
.librarian-review-page .library-review-more-panel .review-mini-form {
  grid-template-columns: minmax(130px, .7fr) minmax(0, 1fr) max-content !important;
}
.librarian-review-page > .admin-grid.admin-grid-2 {
  align-items: stretch !important;
}
.librarian-review-page > .admin-grid.admin-grid-2 .admin-panel {
  min-width: 0 !important;
}
.librarian-review-page > .admin-grid.admin-grid-2 .admin-table-wrap table {
  min-width: 0 !important;
  table-layout: fixed !important;
}
.librarian-review-page > .admin-grid.admin-grid-2 .admin-table-wrap th,
.librarian-review-page > .admin-grid.admin-grid-2 .admin-table-wrap td {
  overflow-wrap: anywhere !important;
  white-space: normal !important;
}

/* Supervisor queue refinement */
.supervisor-queue-page .supervisor-review-card {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 400px) !important;
}
.supervisor-queue-page .supervisor-review-actions {
  position: sticky !important;
  top: 88px !important;
  align-self: start !important;
}
.supervisor-queue-page .supervisor-review-actions form:first-child {
  background: #f0fdf4 !important;
  border-color: rgba(29, 185, 84, .28) !important;
}
.supervisor-queue-page .supervisor-review-links {
  margin-top: 2px !important;
}
.supervisor-queue-page .supervisor-review-links .btn.primary {
  order: 1 !important;
}
.supervisor-queue-page .supervisor-review-links .btn-secondary {
  order: 2 !important;
}

/* Recycle bin */
.recycle-danger-form {
  display: grid !important;
  gap: 18px !important;
}
.recycle-danger-summary {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(160px, 1fr)) !important;
  gap: 12px !important;
}
.recycle-danger-count-card {
  padding: 16px !important;
  border: 1px solid rgba(248, 113, 113, .28) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff7f7 !important;
}
.recycle-danger-count-card span {
  display: block !important;
  color: #7f1d1d !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}
.recycle-danger-count-card strong {
  display: block !important;
  margin-top: 6px !important;
  color: #991b1b !important;
  font-size: 26px !important;
  line-height: 1 !important;
}
.recycle-confirm-field,
.recycle-danger-note {
  max-width: 720px !important;
}
.recycle-danger-actions,
.recycle-section-tools {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.recycle-bin-stack {
  display: grid !important;
  gap: 18px !important;
  margin-top: 18px !important;
}
.recycle-section-head {
  align-items: flex-start !important;
  gap: 14px !important;
}
.recycle-select-all {
  display: inline-flex !important;
  gap: 10px !important;
  align-items: center !important;
  margin: 12px 0 !important;
  padding: 9px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  background: #fff !important;
}
.recycle-list {
  display: grid !important;
  gap: 10px !important;
}
.recycle-item {
  display: grid !important;
  grid-template-columns: 28px minmax(0, 1fr) max-content !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 14px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.recycle-check-cell {
  display: flex !important;
  justify-content: center !important;
}
.recycle-item-main {
  min-width: 0 !important;
  display: grid !important;
  gap: 4px !important;
}
.recycle-item-main strong,
.recycle-item-meta {
  overflow-wrap: anywhere !important;
}
.recycle-item-meta {
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 13px !important;
}
.recycle-item-actions {
  justify-content: flex-end !important;
}
.recycle-empty-state {
  min-height: 120px !important;
}

/* Public home workflow/search preview components */
.workflow-section .workflow-grid {
  display: grid !important;
  grid-template-columns: minmax(260px, 360px) minmax(0, 1fr) !important;
  gap: clamp(18px, 3vw, 34px) !important;
  align-items: start !important;
}
.workflow-section .workflow-tab-bar {
  display: block !important;
  width: 5px !important;
  min-height: 36px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29,185,84,.2) !important;
  align-self: stretch !important;
}
.workflow-section .workflow-tab.active .workflow-tab-bar {
  background: var(--primary, #1db954) !important;
}
.workflow-section .workflow-panels {
  min-width: 0 !important;
}
.workflow-section .workflow-panel {
  display: none !important;
  min-height: 100% !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 24px 70px rgba(10,31,21,.10) !important;
  overflow: hidden !important;
}
.workflow-section .workflow-panel.active {
  display: grid !important;
  grid-template-columns: 12px minmax(0, 1fr) !important;
}
.wf-panel-accent {
  min-height: 100% !important;
  background: var(--primary, #1db954) !important;
}
.wf-accent--2 { background: #0ea5e9 !important; }
.wf-accent--3 { background: #8b5cf6 !important; }
.wf-accent--4 { background: #f59e0b !important; }
.wf-accent--5 { background: #14b8a6 !important; }
.wf-accent--6 { background: #ef4444 !important; }
.wf-panel-body {
  display: grid !important;
  gap: 18px !important;
  padding: clamp(22px, 3vw, 34px) !important;
}
.wf-features {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.wf-features li,
.wf-callout {
  padding: 12px 14px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf8 !important;
}
.wf-callout {
  color: var(--text-dark, #0a0a0a) !important;
  font-weight: 700 !important;
}
.search-preview-shell,
.search-preview-section {
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(280px, 1.1fr) !important;
  gap: clamp(20px, 4vw, 44px) !important;
  align-items: center !important;
}
.search-preview-copy {
  min-width: 0 !important;
  display: grid !important;
  gap: 14px !important;
}
.search-preview-card {
  min-width: 0 !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  padding: 16px !important;
  box-shadow: var(--shadow-lg, 0 16px 48px rgba(10,31,21,.16)) !important;
}
.search-preview-bar,
.search-preview-row {
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f5f7f2 !important;
  padding: 12px 14px !important;
  margin-bottom: 10px !important;
}
.search-preview-row:last-child { margin-bottom: 0 !important; }

/* Research search */
.research-search-page {
  width: min(1240px, calc(100% - 48px)) !important;
  margin: 0 auto !important;
  padding: clamp(28px, 4vw, 54px) 0 !important;
}
.research-search-header {
  margin-bottom: 20px !important;
}
.research-search-shell {
  display: grid !important;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr) !important;
  gap: 20px !important;
  align-items: start !important;
}
.research-filter-panel,
.research-results-panel {
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 45px rgba(10,31,21,.06) !important;
}
.research-filter-panel {
  padding: 18px !important;
  position: sticky !important;
  top: 86px !important;
}
.research-results-panel {
  padding: clamp(16px, 2vw, 22px) !important;
  min-width: 0 !important;
}
.research-results-toolbar,
.result-actions,
.result-badges,
.filter-chip-row,
.search-pagination {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
.research-results-toolbar {
  justify-content: space-between !important;
  margin-bottom: 14px !important;
}
.research-result-list {
  display: grid !important;
  gap: 12px !important;
}
.research-result-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 14px !important;
  padding: 16px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}
.result-main {
  min-width: 0 !important;
}
.result-main h2,
.result-main h3,
.result-main strong {
  overflow-wrap: anywhere !important;
}
.result-meta,
.filter-chip,
.quality-badge {
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 13px !important;
}
.filter-chip,
.quality-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  background: #fff !important;
  font-weight: 800 !important;
}
.quality-badge {
  color: #166534 !important;
  border-color: #bbf7d0 !important;
  background: #f0fdf4 !important;
}

/* Bulk and ZIP imports */
.bulk-batch-page .batch-guidance,
.zip-batch-page .batch-guidance {
  display: grid !important;
  gap: 10px !important;
  padding: 16px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
  margin: 16px 0 !important;
}
.inline-import-feed {
  display: grid !important;
  gap: 14px !important;
}
.inline-import-head,
.inline-import-summary,
.inline-import-actions,
.bulk-toolbar,
.zip-toolbar,
.bulk-page-buttons,
.zip-pager {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: space-between !important;
}
.inline-import-summary {
  justify-content: flex-start !important;
}
.inline-import-bar {
  width: 100% !important;
  height: 10px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  overflow: hidden !important;
  background: #e8f1e9 !important;
  position: relative !important;
}
.inline-import-bar > span,
.inline-import-bar::before {
  content: "" !important;
  display: block !important;
  width: var(--progress, 0%) !important;
  min-width: 8px !important;
  max-width: 100% !important;
  height: 100% !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary, #1db954) !important;
}
.inline-import-log {
  max-height: 280px !important;
  overflow: auto !important;
  padding: 12px !important;
  border: 1px solid #dfe8e0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #07140d !important;
  color: #d7fbe2 !important;
  font: 12px/1.55 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace !important;
  white-space: pre-wrap !important;
}
.bulk-ai-suggestions .panel-head,
.bulk-suggestion-grid {
  display: grid !important;
  gap: 12px !important;
}
.bulk-suggestion-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
}
.bulk-table,
.zip-table {
  min-width: 980px !important;
}
.bulk-title {
  font-weight: 900 !important;
  color: var(--text-dark, #0a0a0a) !important;
  overflow-wrap: anywhere !important;
}
.metadata-only-pill,
.row-error,
.row-warning,
.row-suggestion,
.zip-error {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
  margin-top: 6px !important;
  padding: 6px 9px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  overflow-wrap: anywhere !important;
}
.metadata-only-pill,
.row-suggestion {
  color: #166534 !important;
  background: #dcfce7 !important;
}
.row-warning {
  color: #92400e !important;
  background: #fef3c7 !important;
}
.row-error,
.zip-error {
  color: #991b1b !important;
  background: #fee2e2 !important;
}

/* Setup page */
.setup-tabs {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 18px 0 !important;
}
.setup-tab {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px 14px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark, #0a0a0a) !important;
  font-weight: 800 !important;
}
.setup-tab.active {
  color: #fff !important;
  background: var(--primary, #1db954) !important;
  border-color: var(--primary, #1db954) !important;
}
.setup-panel {
  display: grid !important;
  gap: 18px !important;
}
.admin-help-card {
  padding: 14px 16px !important;
  border: 1px solid #bbf7d0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f0fdf4 !important;
  color: #14532d !important;
}
.academic-import-panel,
.academic-import-form {
  display: grid !important;
  gap: 14px !important;
}
.policy-list {
  display: grid !important;
  gap: 10px !important;
}
.policy-list > * {
  padding: 12px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}

/* Subscription/payment admin panels */
.payment-retry-panel,
.super-admin-billing-note,
.subscription-main-currency-panel,
.subscription-watchlist-panel,
.payment-settings-panel {
  display: grid !important;
  gap: 14px !important;
}
.currency-rate-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 12px !important;
}
.currency-rate-grid > * {
  min-width: 0 !important;
}
.compact-health-list {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.compact-health-list li {
  display: flex !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 10px 12px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}
.subscription-watchlist-table,
.plan-pricing-table {
  min-width: 900px !important;
}
.pricing-input {
  min-width: 110px !important;
}

/* Analytics dashboard */
.date-range-picker {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: end !important;
}
.analytics-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  margin-top: 20px !important;
}
.analytics-card {
  min-width: 0 !important;
  padding: 20px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 16px 42px rgba(10,31,21,.06) !important;
}
.analytics-card--wide {
  grid-column: 1 / -1 !important;
}
.sparkline,
.mini-chart {
  width: 100% !important;
  min-height: 140px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: linear-gradient(180deg, #fbfdfb, #f2f7f2) !important;
}

/* Public project/access/viewer */
.access-request-card,
.access-request-login-card,
.record-claim-form,
.external-document-preview,
.project-public-section {
  display: grid !important;
  gap: 14px !important;
  padding: 16px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.external-document-preview {
  background: #fbfdfb !important;
}
.export-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
.access-request-user {
  padding: 10px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f5f7f2 !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
}
.record-claim-btn,
.access-request-submit {
  width: 100% !important;
}
.secure-viewer,
.viewer-pdf-frame-wrap {
  position: relative !important;
  min-height: min(820px, 82vh) !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fafc !important;
  overflow: hidden !important;
}
.viewer-pdf-frame-wrap iframe,
.secure-viewer iframe,
.secure-viewer object,
.secure-viewer embed {
  width: 100% !important;
  min-height: min(820px, 82vh) !important;
  border: 0 !important;
  display: block !important;
  background: #fff !important;
}
.viewer-watermark {
  pointer-events: none !important;
  position: absolute !important;
  inset: auto 18px 18px auto !important;
  z-index: 4 !important;
  padding: 8px 12px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.82) !important;
  color: rgba(15,23,42,.58) !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}
.viewer-pdf-watermark {
  display: none !important;
}
.viewer-pdf-watermark.bottom {
  display: block !important;
  pointer-events: none !important;
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: 18px !important;
  top: auto !important;
  z-index: 4 !important;
  transform: translateX(-50%) !important;
  max-width: calc(100% - 36px) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  padding: 8px 14px !important;
  border: 1px solid rgba(148, 163, 184, .32) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255, 255, 255, .88) !important;
  color: rgba(15, 23, 42, .7) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}
.viewer-security-note,
.viewer-expiry-note {
  padding: 12px 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f0fdf4 !important;
  color: #14532d !important;
  font-weight: 800 !important;
}
.viewer-expiry-note {
  background: #fffbeb !important;
  color: #92400e !important;
}
.viewer-pdf-loading,
.viewer-pdf-error {
  position: absolute !important;
  inset: 0 !important;
  z-index: 3 !important;
  display: grid !important;
  place-items: center !important;
  padding: 24px !important;
  text-align: center !important;
  background: rgba(248,250,248,.94) !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
}
.viewer-pdf-error { color: #991b1b !important; }

/* Notifications */
.notif-list {
  display: grid !important;
  gap: 10px !important;
}
.notif-group-label {
  margin: 14px 0 2px !important;
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
.notif-item {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: start !important;
  padding: 14px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.notif-item--unread {
  border-color: #bbf7d0 !important;
  background: #f8fff9 !important;
}
.notif-icon {
  width: 42px !important;
  height: 42px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  display: grid !important;
  place-items: center !important;
  background: #eaf8ef !important;
  color: var(--primary-dark, #17a348) !important;
  font-weight: 900 !important;
}
.notif-body {
  min-width: 0 !important;
  display: grid !important;
  gap: 5px !important;
}
.notif-body * {
  overflow-wrap: anywhere !important;
}
.notif-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 8px !important;
}
.notif-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: var(--primary, #1db954) !important;
}
.notif-pref-row {
  display: flex !important;
  justify-content: space-between !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--border-light, #e0e8e2) !important;
}

/* Institution application review */
.institution-application-page .application-summary-grid {
  align-items: stretch !important;
}
.application-decision-panel {
  display: grid !important;
  gap: 14px !important;
}
.application-decision-actions,
.application-reject-form {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
}
.application-detail-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: 12px !important;
}
.application-detail-card {
  min-width: 0 !important;
  padding: 14px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
}
.application-detail-card.is-sensitive {
  border-color: #fed7aa !important;
  background: #fff7ed !important;
}
.application-detail-card strong,
.application-detail-card span,
.application-detail-card p {
  overflow-wrap: anywhere !important;
}

/* Public repository/listing pages */
.public-section {
  min-width: 0 !important;
}
.public-container {
  width: min(1180px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
}
.public-results-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 18px !important;
}
.public-search-panel {
  display: grid !important;
  grid-template-columns: minmax(240px, 1fr) auto !important;
  gap: 10px !important;
  align-items: end !important;
  padding: 16px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 16px 40px rgba(10,31,21,.05) !important;
  margin-bottom: 18px !important;
}
.record-list {
  display: grid !important;
  gap: 12px !important;
}
.record-card,
.result-card {
  display: grid !important;
  gap: 10px !important;
  min-width: 0 !important;
  padding: 16px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 14px 34px rgba(10,31,21,.05) !important;
}
.result-card.compact,
.record-card.compact {
  padding: 14px !important;
}
.record-card h2,
.record-card h3,
.result-card h2,
.result-card h3,
.compact-meta {
  overflow-wrap: anywhere !important;
}
.compact-meta {
  color: var(--text-muted-dark, #6b7b6e) !important;
  font-size: 13px !important;
}
.compact-hero {
  padding-top: clamp(44px, 6vw, 72px) !important;
  padding-bottom: clamp(32px, 5vw, 56px) !important;
}
.topic-cloud,
.compact-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.topic-cloud > *,
.compact-list > * {
  padding: 8px 10px !important;
  border: 1px solid var(--border-light, #e0e8e2) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}

@media (max-width: 1180px) {
  .librarian-review-page .library-review-meta-grid {
    grid-template-columns: repeat(2, minmax(180px, 1fr)) !important;
  }
  .librarian-review-page #bulkActionPanel.table-bulk-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .librarian-review-page #bulkActionPanel.table-bulk-bar > strong,
  .librarian-review-page #bulkActionPanel.table-bulk-bar input[name="bulk_note"] {
    grid-column: 1 / -1 !important;
  }
}
@media (max-width: 980px) {
  .librarian-review-page .admin-filter-bar,
  .librarian-review-page .review-rules-panel .form-grid,
  .research-search-shell,
  .workflow-section .workflow-grid,
  .search-preview-shell,
  .search-preview-section,
  .analytics-grid {
    grid-template-columns: 1fr !important;
  }
  .supervisor-queue-page .supervisor-review-card {
    grid-template-columns: 1fr !important;
  }
  .supervisor-queue-page .supervisor-review-actions,
  .research-filter-panel {
    position: static !important;
  }
}
@media (max-width: 760px) {
  .public-container,
  .research-search-page {
    width: min(100% - 28px, 1180px) !important;
  }
  .librarian-review-page .library-review-card,
  .recycle-item,
  .notif-item,
  .research-result-card {
    grid-template-columns: 1fr !important;
  }
  .librarian-review-page .library-review-check {
    justify-content: flex-start !important;
  }
  .librarian-review-page .library-review-title-row,
  .librarian-review-page .library-review-primary-actions,
  .notif-actions,
  .application-decision-actions,
  .application-reject-form {
    justify-content: flex-start !important;
  }
  .librarian-review-page .library-review-secondary-actions,
  .librarian-review-page .library-review-meta-grid,
  .recycle-danger-summary,
  .application-detail-grid,
  .public-search-panel {
    grid-template-columns: 1fr !important;
  }
  .librarian-review-page .review-mini-form,
  .librarian-review-page .library-review-more-panel .review-mini-form {
    grid-template-columns: 1fr !important;
  }
  .librarian-review-page .review-mini-form .btn,
  .librarian-review-page .library-review-primary-actions .btn,
  .librarian-review-page .library-review-primary-actions form,
  .recycle-item-actions,
  .recycle-item-actions .btn,
  .research-result-card .btn,
  .public-search-panel .btn {
    width: 100% !important;
  }
  .inline-import-head,
  .inline-import-summary,
  .inline-import-actions,
  .bulk-toolbar,
  .zip-toolbar,
  .bulk-page-buttons,
  .zip-pager {
    justify-content: flex-start !important;
  }
}
.recycle-section-panel {
  display: grid !important;
  gap: 12px !important;
}
.wf-accent--1 { background: var(--primary, #1db954) !important; }

/* Signup choice fallback styles kept in app.css so the page is not dependent on inline CSS only */
.signup-v3 {
  display: block !important;
  min-height: 100vh !important;
  padding: clamp(24px, 4vw, 56px) 20px !important;
  background: #f5faf6 !important;
}
.signup-v3-inner {
  max-width: 1080px !important;
  margin: 0 auto !important;
}
.signup-v3-hero {
  margin-bottom: 20px !important;
  padding: clamp(28px, 4vw, 48px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #0b3d2a !important;
  color: #fff !important;
  box-shadow: 0 24px 60px rgba(10,31,21,.18) !important;
}
.signup-v3-hero h1 {
  margin: 0 0 12px !important;
  font-size: clamp(28px, 4vw, 44px) !important;
  line-height: 1.05 !important;
}
.signup-v3-hero p {
  max-width: 680px !important;
  margin: 0 !important;
  color: rgba(255,255,255,.86) !important;
}
.signup-v3-pill {
  display: inline-flex !important;
  margin-top: 14px !important;
  padding: 6px 14px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.12) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
.signup-v3-card {
  padding: clamp(22px, 3vw, 36px) !important;
  border: 1px solid #e3ece4 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 18px 50px rgba(10,31,21,.06) !important;
}
.signup-v3-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, .8fr) !important;
  gap: 16px !important;
  align-items: start !important;
}
.signup-v3-side {
  display: grid !important;
  gap: 12px !important;
}
.signup-v3-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
  border: 0 !important;
}
.signup-v3-legend {
  grid-column: 1 / -1 !important;
  margin-bottom: 2px !important;
  color: #07140d !important;
  font-weight: 900 !important;
}
.signup-v3-card-option {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 22px !important;
  gap: 14px !important;
  align-items: start !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 16px !important;
  border: 1.5px solid #dfe9df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fbfdfb !important;
  cursor: pointer !important;
}
.signup-v3-card-option input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.signup-v3-icon,
.signup-v3-check {
  display: grid !important;
  place-items: center !important;
  flex-shrink: 0 !important;
}
.signup-v3-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #e8f7ee !important;
  color: #0f6b34 !important;
}
.signup-v3-check {
  width: 22px !important;
  height: 22px !important;
  justify-self: end !important;
  border: 1.5px solid #c4d4c7 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: transparent !important;
}
.signup-v3-card-option.is-selected {
  border-color: #1db954 !important;
  background: #f2fff6 !important;
  box-shadow: 0 12px 24px rgba(29,185,84,.16) !important;
}
.signup-v3-card-option.is-selected .signup-v3-icon,
.signup-v3-card-option.is-selected .signup-v3-check {
  background: #1db954 !important;
  color: #fff !important;
  border-color: #1db954 !important;
}
.signup-v3-body {
  min-width: 0 !important;
  display: grid !important;
  gap: 4px !important;
}
.signup-v3-body strong {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.signup-v3-body small,
.signup-v3-desc,
.signup-v3-note {
  overflow-wrap: break-word !important;
  word-break: normal !important;
}
.signup-v3-desc,
.signup-v3-field-help {
  color: #566c5a !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}
.signup-v3-note {
  color: #0f6b34 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
.signup-v3-field,
.signup-v3-field-label {
  display: block !important;
}
.signup-v3-field[hidden],
.signup-v3-field-label[hidden],
[data-institution-field][hidden],
[data-study-level-field][hidden] {
  display: none !important;
}
.signup-v3-field {
  margin: 0 0 14px !important;
}
.signup-v3-field-label {
  margin-bottom: 6px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}
.signup-v3-actions,
.signup-v3-sso {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.signup-v3-btn,
.signup-v3-sso-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  min-height: 44px !important;
  padding: 11px 18px !important;
  border: 1.5px solid #dfe9df !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0b3d2a !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}
.signup-v3-btn-primary {
  background: #16a34a !important;
  border-color: #16a34a !important;
  color: #fff !important;
}
.signup-v3-btn-secondary {
  background: #fff !important;
  color: #0b3d2a !important;
}
.signup-v3-divider {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 24px 0 16px !important;
  color: #9fb4a5 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
}
.signup-v3-divider::before,
.signup-v3-divider::after {
  content: "" !important;
  flex: 1 !important;
  height: 1px !important;
  background: #dfe9df !important;
}
.signup-v3-sso-prompt {
  text-align: center !important;
  font-weight: 800 !important;
}
.signup-v3-sso {
  justify-content: center !important;
}
.signup-v3-sso-btn {
  width: min(100%, 420px) !important;
  border-radius: var(--inrep-radius, 10px) !important;
}
@media (max-width: 900px) {
  .signup-v3-layout {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 640px) {
  .signup-v3-grid {
    grid-template-columns: 1fr !important;
  }
  .signup-v3-actions .signup-v3-btn,
  .signup-v3-sso-btn {
    width: 100% !important;
  }
}

/* 20260523: password controls, keyword autofill feedback, and table squeeze hardening */
.password-wrap,
.password-control {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}
.password-wrap input,
.password-control input {
  width: 100% !important;
  min-width: 0 !important;
  padding-right: 76px !important;
}
.password-wrap .password-toggle,
.password-control .password-toggle,
.password-toggle {
  position: absolute !important;
  right: 8px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  min-width: 52px !important;
  min-height: 32px !important;
  padding: 6px 10px !important;
  border: 1px solid rgba(29,185,84,.22) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #eefbf2 !important;
  color: #065f36 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  cursor: pointer !important;
  box-shadow: none !important;
  z-index: 2 !important;
}
.password-wrap .password-toggle:hover,
.password-control .password-toggle:hover,
.password-toggle:hover {
  background: #daf7e4 !important;
  color: #044b2a !important;
}
.password-checklist {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 6px 12px !important;
  margin: 9px 0 0 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(224,232,226,.95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf8 !important;
  list-style: none !important;
}
.password-checklist li {
  color: #7a5a00 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
}
.password-checklist li::before {
  content: '- ' !important;
}
.password-checklist li.passed {
  color: #087a3d !important;
}
.password-checklist li.passed::before {
  content: 'OK ' !important;
}
.password-help,
.password-match-help {
  display: block !important;
  margin-top: 7px !important;
  color: #6b7280 !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  line-height: 1.4 !important;
}
.password-help.ok,
.password-match-help.ok { color: #087a3d !important; }
.password-help.error,
.password-match-help.error { color: #b42318 !important; }
.form-live-summary {
  grid-column: 1 / -1 !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(234,179,8,.28) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fffbea !important;
  color: #7a5a00 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}
.form-live-summary.ok {
  border-color: rgba(29,185,84,.25) !important;
  background: #f0fdf4 !important;
  color: #087a3d !important;
}
.admin-table-wrap,
.table-responsive {
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
  -webkit-overflow-scrolling: touch !important;
}
.admin-table-wrap table,
.table-responsive table,
.admin-table {
  table-layout: auto !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}
.admin-table-wrap th,
.admin-table-wrap td,
.table-responsive th,
.table-responsive td,
.admin-table th,
.admin-table td {
  min-width: 0 !important;
  max-width: none !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  white-space: normal !important;
  vertical-align: top !important;
}
.catalogue-integration-panel {
  min-width: 0 !important;
}
.catalogue-table-wrap {
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.catalogue-integration-table {
  min-width: 680px !important;
  width: 100% !important;
  table-layout: auto !important;
}
.catalogue-integration-table th,
.catalogue-integration-table td {
  padding: 13px 14px !important;
  line-height: 1.45 !important;
}
.catalogue-integration-table th:first-child,
.catalogue-integration-table td:first-child {
  width: 44% !important;
  min-width: 260px !important;
}
.catalogue-integration-table th:nth-child(2),
.catalogue-integration-table td:nth-child(2) {
  width: 18% !important;
  min-width: 120px !important;
}
.catalogue-integration-table th:nth-child(3),
.catalogue-integration-table td:nth-child(3) {
  width: 18% !important;
  min-width: 120px !important;
}
.catalogue-integration-table th:nth-child(4),
.catalogue-integration-table td:nth-child(4) {
  width: 20% !important;
  min-width: 150px !important;
}
.admin-grid .admin-panel .admin-table-wrap table:not(.catalogue-integration-table) {
  min-width: 680px !important;
}
@media (max-width: 760px) {
  .password-checklist { grid-template-columns: 1fr !important; }
  .catalogue-table-wrap[data-mobile-card="1"] {
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] table,
  .catalogue-table-wrap[data-mobile-card="1"] thead,
  .catalogue-table-wrap[data-mobile-card="1"] tbody,
  .catalogue-table-wrap[data-mobile-card="1"] tr,
  .catalogue-table-wrap[data-mobile-card="1"] th,
  .catalogue-table-wrap[data-mobile-card="1"] td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] thead {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] tbody {
    display: grid !important;
    gap: 12px !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] tr {
    padding: 12px !important;
    border: 1px solid rgba(224,232,226,.95) !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] td {
    display: grid !important;
    grid-template-columns: minmax(92px, .45fr) minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 9px 0 !important;
    border-bottom: 1px solid rgba(224,232,226,.72) !important;
  }
  .catalogue-table-wrap[data-mobile-card="1"] td:last-child { border-bottom: 0 !important; }
  .catalogue-table-wrap[data-mobile-card="1"] td::before {
    content: attr(data-label) !important;
    color: #6b7b6e !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
  }
}

/* Launch readiness bulk/table/form validation overrides */
.table-bulk-bar {
  position: sticky !important;
  top: 72px !important;
  z-index: 30 !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 12px 0 16px !important;
  padding: 12px !important;
  border: 1px solid rgba(148, 163, 184, .32) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255, 255, 255, .96) !important;
  box-shadow: 0 14px 34px rgba(15, 23, 42, .08) !important;
  backdrop-filter: blur(12px) !important;
  overflow: visible !important;
}
.table-bulk-bar strong { white-space: nowrap !important; font-weight: 850 !important; color: #0f172a !important; }
.table-bulk-bar input,
.table-bulk-bar select,
.table-bulk-bar textarea {
  flex: 1 1 220px !important;
  min-width: 160px !important;
  max-width: 100% !important;
  height: 38px !important;
}
.table-bulk-bar .btn,
.table-bulk-bar button {
  flex: 0 0 auto !important;
  min-height: 38px !important;
  white-space: nowrap !important;
}
.librarian-review-page #bulkActionPanel.library-bulk-panel.table-bulk-bar {
  display: grid !important;
  grid-template-columns: minmax(190px, .8fr) minmax(260px, 1fr) minmax(170px, .7fr) minmax(260px, 1.1fr) !important;
  gap: 12px !important;
  align-items: end !important;
  padding: 14px !important;
}
.librarian-review-page .bulk-selection-summary {
  display: grid !important;
  gap: 3px !important;
  align-self: center !important;
}
.librarian-review-page .bulk-selection-summary small,
.librarian-review-page .bulk-field span {
  color: #64748b !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}
.librarian-review-page .bulk-action-group {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
.librarian-review-page .bulk-action-group.secondary {
  grid-column: 2 / -1 !important;
}
.librarian-review-page .bulk-field {
  display: grid !important;
  gap: 5px !important;
  min-width: 0 !important;
  margin: 0 !important;
}
.librarian-review-page #bulkActionPanel .bulk-field input {
  width: 100% !important;
  min-width: 0 !important;
}
@media (max-width: 980px) {
  .librarian-review-page #bulkActionPanel.library-bulk-panel.table-bulk-bar {
    grid-template-columns: 1fr !important;
  }
  .librarian-review-page .bulk-action-group.secondary {
    grid-column: auto !important;
  }
  .librarian-review-page .bulk-action-group .btn,
  .librarian-review-page .bulk-action-group button {
    flex: 1 1 160px !important;
  }
}
.admin-page-size-selector {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 10px 14px !important;
  margin: 10px 0 16px !important;
  padding: 10px 12px !important;
  border: 1px solid rgba(226,232,240,.95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
}
.admin-page-size-selector label { display: inline-flex !important; align-items: center !important; gap: 8px !important; margin: 0 !important; font-weight: 750 !important; color: #334155 !important; }
.admin-page-size-selector select { width: auto !important; min-width: 92px !important; height: 38px !important; }
.admin-page-size-selector small { color: #64748b !important; }
.validation-checklist,
.validation-gate-list {
  display: grid !important;
  gap: 8px !important;
  margin: 10px 0 !important;
  padding: 10px !important;
  border: 1px solid rgba(226,232,240,.95) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fafc !important;
}
.validation-checklist__item,
.validation-gate-list li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
  margin: 0 !important;
  color: #334155 !important;
  line-height: 1.45 !important;
}
.validation-checklist__item.is-pass::before,
.validation-gate-list li.is-pass::before { content: "OK"; color: #166534; font-weight: 900; }
.validation-checklist__item.is-fail::before,
.validation-gate-list li.is-fail::before { content: "Fix"; color: #991b1b; font-weight: 900; }
button[disabled], .btn.disabled, .btn[aria-disabled="true"] { opacity: .55 !important; cursor: not-allowed !important; pointer-events: none !important; }
.floating-form-actions {
  position: fixed !important;
  left: max(16px, env(safe-area-inset-left)) !important;
  right: max(16px, env(safe-area-inset-right)) !important;
  bottom: max(16px, env(safe-area-inset-bottom)) !important;
  z-index: 80 !important;
  display: none !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  max-width: 920px !important;
  margin: 0 auto !important;
  padding: 12px 14px !important;
  border: 1px solid rgba(148, 163, 184, .38) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(255,255,255,.98) !important;
  box-shadow: 0 20px 55px rgba(15,23,42,.18) !important;
  backdrop-filter: blur(16px) !important;
}
.floating-form-actions.is-visible { display: flex !important; }
.floating-form-actions strong { color: #0f172a !important; font-size: 14px !important; }
.floating-form-actions .btn { min-height: 40px !important; }
@media (max-width: 760px) {
  .table-bulk-bar { top: 8px !important; padding: 10px !important; border-radius: var(--inrep-radius, 10px) !important; }
  .table-bulk-bar strong,
  .table-bulk-bar input,
  .table-bulk-bar select,
  .table-bulk-bar textarea,
  .table-bulk-bar .btn,
  .table-bulk-bar button { flex: 1 1 100% !important; width: 100% !important; }
  .admin-page-size-selector { align-items: stretch !important; }
  .admin-page-size-selector label, .admin-page-size-selector select { width: 100% !important; }
  .floating-form-actions { align-items: stretch !important; flex-direction: column !important; }
  .floating-form-actions .btn { width: 100% !important; }
}
.admin-all-rows-progress {
  position: fixed !important;
  inset: 0 !important;
  z-index: 120 !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(15, 23, 42, .28) !important;
  backdrop-filter: blur(4px) !important;
}
.admin-all-rows-progress > div {
  display: grid !important;
  gap: 10px !important;
  max-width: 420px !important;
  width: calc(100% - 32px) !important;
  padding: 18px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  border: 1px solid rgba(226,232,240,.95) !important;
  background: #fff !important;
  box-shadow: 0 28px 70px rgba(15,23,42,.18) !important;
}
.admin-all-rows-progress small { color: #64748b !important; }

/* Recycle bin layout hardening: keep row actions in their own column, not under the checkbox. */
.recycle-bin-stack .recycle-item {
  grid-template-columns: 34px minmax(220px, 1fr) minmax(150px, max-content) minmax(190px, max-content) !important;
  align-items: center !important;
  column-gap: 16px !important;
  row-gap: 10px !important;
  min-height: 76px !important;
  padding: 16px 18px !important;
}
.recycle-bin-stack .recycle-check-cell {
  grid-column: 1 !important;
  grid-row: 1 !important;
  justify-content: center !important;
  align-self: center !important;
}
.recycle-bin-stack .recycle-item-main {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 0 !important;
}
.recycle-bin-stack .recycle-item-main strong {
  display: block !important;
  color: #10271b !important;
  line-height: 1.25 !important;
}
.recycle-bin-stack .recycle-item-main small {
  display: block !important;
  margin-top: 3px !important;
  color: #63756a !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
}
.recycle-bin-stack .recycle-item-meta {
  grid-column: 3 !important;
  grid-row: 1 !important;
  justify-self: end !important;
  min-width: 150px !important;
  text-align: right !important;
  white-space: nowrap !important;
}
.recycle-bin-stack .recycle-item-meta span {
  display: inline !important;
  margin-right: 4px !important;
  color: #6f8175 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
.recycle-bin-stack .recycle-item-meta strong {
  display: inline !important;
  color: #53645b !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}
.recycle-bin-stack .recycle-item-actions {
  grid-column: 4 !important;
  grid-row: 1 !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 190px !important;
  width: auto !important;
}
.recycle-bin-stack .recycle-item-actions form {
  display: inline-flex !important;
  width: auto !important;
  margin: 0 !important;
}
.recycle-bin-stack .recycle-item-actions .btn,
.recycle-bin-stack .recycle-item-actions button {
  width: auto !important;
  min-width: 82px !important;
  min-height: 34px !important;
  padding: 7px 11px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  justify-content: center !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
}
.recycle-bin-stack .recycle-item-actions .btn.danger,
.recycle-bin-stack .recycle-item-actions button.danger {
  min-width: 104px !important;
}
.recycle-bin-stack .recycle-section-panel {
  overflow: visible !important;
}
.recycle-bin-stack .recycle-list {
  min-width: 0 !important;
}
.recycle-bin-stack .recycle-select-all {
  margin: 0 !important;
}
.recycle-bin-stack .recycle-section-head {
  align-items: center !important;
}
@media (max-width: 1180px) {
  .recycle-bin-stack .recycle-item {
    grid-template-columns: 34px minmax(0, 1fr) minmax(180px, max-content) !important;
  }
  .recycle-bin-stack .recycle-item-actions {
    grid-column: 2 / -1 !important;
    grid-row: 2 !important;
    justify-content: flex-start !important;
    min-width: 0 !important;
  }
  .recycle-bin-stack .recycle-item-meta {
    grid-column: 3 !important;
  }
}
@media (max-width: 760px) {
  .recycle-page-header,
  .recycle-section-head {
    align-items: stretch !important;
  }
  .recycle-bin-stack .recycle-section-tools,
  .recycle-page-header .admin-actions {
    width: 100% !important;
    justify-content: flex-start !important;
  }
  .recycle-bin-stack .recycle-item {
    grid-template-columns: 28px minmax(0, 1fr) !important;
    padding: 14px !important;
  }
  .recycle-bin-stack .recycle-check-cell {
    grid-column: 1 !important;
    grid-row: 1 !important;
    align-self: start !important;
    padding-top: 2px !important;
  }
  .recycle-bin-stack .recycle-item-main {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }
  .recycle-bin-stack .recycle-item-meta {
    grid-column: 2 !important;
    grid-row: 2 !important;
    justify-self: start !important;
    min-width: 0 !important;
    text-align: left !important;
    white-space: normal !important;
  }
  .recycle-bin-stack .recycle-item-actions {
    grid-column: 1 / -1 !important;
    grid-row: 3 !important;
    width: 100% !important;
    min-width: 0 !important;
    justify-content: stretch !important;
  }
  .recycle-bin-stack .recycle-item-actions form {
    flex: 1 1 0 !important;
  }
  .recycle-bin-stack .recycle-item-actions .btn,
  .recycle-bin-stack .recycle-item-actions button {
    width: 100% !important;
    min-width: 0 !important;
  }
}

/* Canonical public navigation */
.public-body .mkt-nav {
  position: sticky !important;
  top: 0 !important;
  z-index: 250 !important;
  width: 100% !important;
  min-height: 64px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) minmax(220px, 340px) auto !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 12px clamp(16px, 3vw, 32px) !important;
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: blur(18px) !important;
  border-bottom: 1px solid rgba(15,23,42,.08) !important;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease !important;
}

.public-body .mkt-nav.scrolled {
  box-shadow: 0 12px 32px rgba(15,23,42,.08) !important;
}

.public-body .mkt-nav.nav-hidden {
  transform: translateY(-100%) !important;
}

.public-body .mkt-nav-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: max-content !important;
  color: var(--text-dark) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.public-body .mkt-nav-items {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  min-width: 0 !important;
}

.public-body .mkt-nav-item,
.public-body .mkt-nav-menu-btn,
.public-body .mkt-nav-signin {
  min-height: 40px !important;
  padding: 9px 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: transparent !important;
  color: var(--text-muted) !important;
  font: inherit !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.public-body .mkt-nav-item:hover,
.public-body .mkt-nav-menu-btn:hover,
.public-body .mkt-nav-group.open > .mkt-nav-menu-btn {
  background: var(--bg-light) !important;
  color: var(--text-dark) !important;
}

.public-body .mkt-nav-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  white-space: nowrap !important;
}

.public-body .mkt-nav-toggle {
  display: none !important;
  width: 42px !important;
  height: 42px !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid rgba(15,23,42,.12) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: var(--text-dark) !important;
}

.public-body .mkt-mobile-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 260 !important;
  background: rgba(15,23,42,.42) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .22s ease !important;
}

.public-body .mkt-mobile-drawer {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  z-index: 270 !important;
  width: min(88vw, 380px) !important;
  height: 100vh !important;
  padding: 18px !important;
  background: #fff !important;
  box-shadow: -24px 0 60px rgba(15,23,42,.18) !important;
  transform: translateX(104%) !important;
  transition: transform .26s ease !important;
  overflow-y: auto !important;
}

body.public-nav-open {
  overflow: hidden !important;
}

body.public-nav-open .mkt-mobile-overlay {
  opacity: 1 !important;
  pointer-events: auto !important;
}

body.public-nav-open .mkt-mobile-drawer {
  transform: translateX(0) !important;
}

.public-body .mkt-mobile-drawer-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 16px !important;
}

.public-body .mkt-mobile-drawer a,
.public-body .mkt-mobile-drawer button {
  min-height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 11px 12px !important;
  border: 0 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: transparent !important;
  color: var(--text-dark) !important;
  font: inherit !important;
  font-weight: 600 !important;
  text-align: left !important;
  text-decoration: none !important;
}

.public-body .mkt-mobile-drawer a:hover,
.public-body .mkt-mobile-drawer button:hover {
  background: var(--bg-light) !important;
}

.public-body .mkt-mobile-drawer .mkt-dropdown {
  position: static !important;
  display: none !important;
  width: 100% !important;
  margin: 4px 0 8px !important;
  padding: 6px !important;
  border: 1px solid rgba(15,23,42,.08) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  box-shadow: none !important;
}

.public-body .mkt-mobile-drawer .mkt-nav-group.open > .mkt-dropdown {
  display: grid !important;
}

@media (max-width: 1024px) {
  .public-body .mkt-nav {
    grid-template-columns: auto 1fr auto !important;
  }

  .public-body .mkt-nav-items,
  .public-body .mkt-nav-search,
  .public-body .mkt-nav-actions {
    display: none !important;
  }

  .public-body .mkt-nav-toggle {
    display: inline-flex !important;
  }
}

/* Recycle bin workflow hardening: visible selected actions beside each list. */
.recycle-command-zone {
  border: 1px solid rgba(15, 118, 110, .12) !important;
  background: linear-gradient(180deg, #ffffff 0%, #fbfefc 100%) !important;
}
.recycle-primary-actions {
  padding: 12px !important;
  border: 1px solid rgba(29, 185, 84, .16) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fff9 !important;
}
.recycle-cleanup-actions {
  padding-top: 2px !important;
}
.recycle-action-label {
  flex: 0 0 100% !important;
  font-weight: 800 !important;
  color: #64748b !important;
}
.recycle-section-tools {
  justify-content: flex-end !important;
}
.recycle-section-tools .btn {
  min-height: 34px !important;
  white-space: nowrap !important;
}
.recycle-bin-stack .status-badge.muted,
.status-badge.muted {
  background: #f8fafc !important;
  color: #475569 !important;
  border-color: #e2e8f0 !important;
}
.recycle-bin-stack .recycle-item {
  grid-template-columns: 34px minmax(0, 1fr) minmax(160px, max-content) !important;
  grid-template-rows: auto auto !important;
  align-items: start !important;
  column-gap: 16px !important;
  row-gap: 12px !important;
  padding: 16px 18px !important;
}
.recycle-bin-stack .recycle-check-cell {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  align-self: start !important;
  padding-top: 3px !important;
}
.recycle-bin-stack .recycle-item-main {
  grid-column: 2 !important;
  grid-row: 1 !important;
}
.recycle-bin-stack .recycle-item-meta {
  grid-column: 3 !important;
  grid-row: 1 !important;
  justify-self: end !important;
  text-align: right !important;
  min-width: 160px !important;
}
.recycle-bin-stack .recycle-item-actions {
  grid-column: 2 / -1 !important;
  grid-row: 2 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 8px !important;
  width: 100% !important;
  min-width: 0 !important;
}
.recycle-bin-stack .recycle-item-actions form {
  display: inline-flex !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 !important;
}
.recycle-bin-stack .recycle-item-actions .btn,
.recycle-bin-stack .recycle-item-actions button {
  display: inline-flex !important;
  width: auto !important;
  min-width: 116px !important;
  min-height: 34px !important;
  padding: 7px 13px !important;
  border-radius: var(--inrep-radius, 10px) !important;
  justify-content: center !important;
  white-space: nowrap !important;
  overflow: visible !important;
  text-overflow: clip !important;
}
@media (max-width: 980px) {
  .recycle-section-tools {
    justify-content: flex-start !important;
  }
  .recycle-bin-stack .recycle-item {
    grid-template-columns: 30px minmax(0, 1fr) !important;
  }
  .recycle-bin-stack .recycle-item-meta {
    grid-column: 2 !important;
    grid-row: 2 !important;
    justify-self: start !important;
    text-align: left !important;
    min-width: 0 !important;
    white-space: normal !important;
  }
  .recycle-bin-stack .recycle-item-actions {
    grid-column: 2 !important;
    grid-row: 3 !important;
  }
}
@media (max-width: 640px) {
  .recycle-danger-actions .btn,
  .recycle-section-tools .btn {
    width: 100% !important;
    justify-content: center !important;
  }
  .recycle-bin-stack .recycle-item-actions form,
  .recycle-bin-stack .recycle-item-actions .btn,
  .recycle-bin-stack .recycle-item-actions button {
    width: 100% !important;
    min-width: 0 !important;
  }
}

/* 20260523: student wizard password controls match the existing auth layout */
.student-register-wizard .wizard-step label {
  align-content: start !important;
}
.student-register-wizard .password-control {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  min-height: 52px !important;
  align-self: start !important;
}
.student-register-wizard .password-control input {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  height: 52px !important;
  min-height: 52px !important;
  padding: 12px 14px !important;
  box-sizing: border-box !important;
}
.student-register-wizard .password-control .password-toggle {
  position: static !important;
  inset: auto !important;
  transform: none !important;
  flex: 0 0 92px !important;
  width: 92px !important;
  min-width: 92px !important;
  height: 52px !important;
  min-height: 52px !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  color: #0f172a !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  box-shadow: none !important;
}
.student-register-wizard .password-control .password-toggle:hover {
  border-color: #98a2b3 !important;
  background: #f8fafc !important;
  color: #0f172a !important;
}
.password-checklist li::before {
  content: "\2022 " !important;
}
.password-checklist li.passed::before {
  content: "\2713 " !important;
}
@media (max-width: 480px) {
  .student-register-wizard .password-control {
    gap: 8px !important;
  }
  .student-register-wizard .password-control .password-toggle {
    flex-basis: 76px !important;
    width: 76px !important;
    min-width: 76px !important;
    padding: 0 10px !important;
  }
}

/* 2026-05-26 homepage cross-check fix: the search preview wrapper must not be a grid.
   The previous combined selector made .search-preview-shell itself a two-column grid,
   shrinking the real .search-preview-section into the first column and leaving a large blank area. */
.chrome-dot--red { background: #ff5f57 !important; }
.chrome-dot--yellow { background: #febc2e !important; }
.chrome-dot--green { background: #28c840 !important; }
.home-preview-cta { margin-top: 20px !important; justify-self: start !important; }

.search-preview-shell {
  display: block !important;
  grid-template-columns: none !important;
  gap: 0 !important;
  width: 100% !important;
  margin: 0 !important;
  padding: clamp(56px, 7vw, 88px) 0 !important;
  background: #fff !important;
}

.search-preview-section,
.search-preview-section.container {
  display: grid !important;
  grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr) !important;
  align-items: center !important;
  gap: clamp(28px, 5vw, 64px) !important;
  width: min(1120px, calc(100% - 48px)) !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  background: transparent !important;
  color: var(--text-dark, #0f1f16) !important;
}

.search-preview-copy {
  min-width: 0 !important;
  max-width: 420px !important;
  display: grid !important;
  gap: 14px !important;
}
.search-preview-copy h2 {
  margin: 0 !important;
  color: var(--text-dark, #0f1f16) !important;
  font-family: var(--font-display, inherit) !important;
  font-size: clamp(32px, 4vw, 52px) !important;
  line-height: 1.02 !important;
  letter-spacing: -.045em !important;
}
.search-preview-copy p {
  margin: 0 !important;
  color: var(--text-muted-dark, #526256) !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}
.search-preview-card {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: clamp(18px, 2.6vw, 28px) !important;
  border: 1px solid var(--border-light, #dfe9e3) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #fff !important;
  box-shadow: 0 22px 58px rgba(10, 31, 21, .10) !important;
}
.search-preview-bar,
.search-preview-row {
  width: 100% !important;
  min-width: 0 !important;
  border: 1px solid var(--border-light, #dfe9e3) !important;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8fbf8 !important;
  margin: 0 0 10px !important;
  padding: 13px 15px !important;
  color: var(--text-muted-dark, #526256) !important;
}
.search-preview-row:last-child { margin-bottom: 0 !important; }
.search-preview-row b {
  display: block !important;
  color: var(--text-dark, #0f1f16) !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  margin-bottom: 4px !important;
  overflow-wrap: anywhere !important;
}
.search-preview-row span {
  color: var(--text-muted-dark, #526256) !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

@media (max-width: 900px) {
  .search-preview-section,
  .search-preview-section.container {
    grid-template-columns: 1fr !important;
    width: min(720px, calc(100% - 32px)) !important;
    gap: 24px !important;
  }
  .search-preview-copy { max-width: none !important; }
  .home-preview-cta { justify-self: stretch !important; width: 100% !important; }
}

@media (max-width: 520px) {
  .search-preview-shell { padding: 46px 0 !important; }
  .search-preview-section,
  .search-preview-section.container { width: calc(100% - 24px) !important; }
  .search-preview-card { padding: 14px !important; border-radius: var(--inrep-radius, 10px) !important; }
  .search-preview-copy h2 { font-size: 32px !important; }
}



/* 2026-05-27 homepage workflow refresh: simpler, cleaner public workflow section */
.public-body .workflow-section {
  background: var(--bg-light);
}
.public-body .workflow-section .section-heading {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.public-body .workflow-section .section-sub {
  max-width: 720px;
  margin: 0 auto;
}
.public-body .workflow-section .workflow-grid {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
.public-body .workflow-section .workflow-tabs {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.public-body .workflow-section .workflow-tab {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  width: 100%;
  min-height: 68px;
  padding: 16px 18px;
  border: 1px solid transparent;
  border-radius: var(--inrep-radius, 10px) !important;
  background: transparent;
  box-shadow: none;
}
.public-body .workflow-section .workflow-tab:hover {
  background: rgba(255,255,255,.55);
}
.public-body .workflow-section .workflow-tab.active {
  background: #fff;
  border-color: var(--border-light);
  border-left-color: var(--primary);
  box-shadow: none;
}
.public-body .workflow-section .workflow-tab-num {
  min-width: 34px;
  font-size: 18px;
  line-height: 1;
}
.public-body .workflow-section .workflow-tab-label {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.35;
}
.public-body .workflow-section .workflow-tab-bar {
  width: 4px;
  height: 34px;
  border-radius: var(--inrep-radius, 10px) !important;
  background: rgba(29, 185, 84, .18);
}
.public-body .workflow-section .workflow-tab.active .workflow-tab-bar {
  background: var(--primary);
}
.public-body .workflow-section .workflow-panels {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  min-height: 0;
}
.public-body .workflow-section .workflow-panel {
  display: none;
  align-items: stretch;
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: var(--inrep-radius, 10px) !important;
  overflow: hidden;
}
.public-body .workflow-section .workflow-panel.active {
  display: flex;
}
.public-body .workflow-section .wf-panel-accent {
  width: 6px;
  min-width: 6px;
  background: var(--primary);
}
.public-body .workflow-section .wf-panel-body {
  width: 100%;
  padding: 32px;
}
.public-body .workflow-section .workflow-panel h3 {
  margin: 0 0 12px;
  font-size: clamp(28px, 3vw, 34px);
  line-height: 1.1;
}
.public-body .workflow-section .workflow-panel p {
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-muted-dark);
  max-width: 720px;
}
.public-body .workflow-section .workflow-panel p + p {
  margin-top: 12px;
}
.public-body .workflow-section .wf-features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}
.public-body .workflow-section .wf-features li {
  margin: 0;
  padding: 14px 16px;
  border: 1px solid #e5ece3;
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f8faf7;
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-dark);
}
.public-body .workflow-section .wf-callout {
  margin-top: 18px;
  padding: 0;
  border: 0;
  background: transparent;
}
.public-body .workflow-section .wf-callout strong {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--primary);
}
.public-body .workflow-section .wf-callout span {
  display: block;
  color: var(--text-muted-dark);
  font-size: 14px;
  line-height: 1.6;
}
@media (max-width: 960px) {
  .public-body .workflow-section .workflow-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .public-body .workflow-section .workflow-tabs {
    flex-direction: row;
    overflow-x: auto;
    padding-bottom: 6px;
  }
  .public-body .workflow-section .workflow-tab {
    min-width: 160px;
  }
  .public-body .workflow-section .workflow-panel.active {
    display: block;
  }
  .public-body .workflow-section .wf-panel-accent {
    width: 100%;
    min-width: 0;
    height: 6px;
  }
  .public-body .workflow-section .wf-panel-body {
    padding: 24px;
  }
}
@media (max-width: 640px) {
  .public-body .workflow-section .workflow-panel h3 {
    font-size: 24px;
  }
  .public-body .workflow-section .workflow-panel p {
    font-size: 15px;
  }
  .public-body .workflow-section .wf-features {
    grid-template-columns: 1fr;
  }
}

/* Universal button radius matching the uploaded reference. */
:root { --inrep-radius: 10px; --inrep-button-radius: var(--inrep-radius); }
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"],
.btn,
.btn.primary, .btn.dark, .btn.green, .btn.lime,
.btn-primary, .btn-hero-primary, .btn-hero-secondary,
.btn-dark, .btn-outline-green, .btn-outline-white,
.mkt-nav-signup, .btn-new-repo,
.btn-sm, .btn.small,
.btn-lg,
.btn.tiny, .btn-xs,
button.btn,
a.btn,
input[type="submit"].btn {
  border-radius: var(--inrep-radius, 10px) !important;
}

/* ═══════════════════════════════════════════════════════
   HOME PAGE — Recently published records grid
   ═══════════════════════════════════════════════════════ */
.ir-home-records-grid {
  width: min(1200px, calc(100% - 48px));
  margin: 28px auto 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.ir-home-card { cursor: default; }
.ir-home-card[hidden] { display: none !important; }
@media (max-width: 1024px) {
  .ir-home-records-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .ir-home-records-grid { grid-template-columns: 1fr; }
}

/* 2026-05-31: final mobile/dashboard responsive hardening */
html,
body {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

body.admin-fullscreen .admin-shell,
body.admin-fullscreen .admin-main,
.admin-page,
.admin-panel,
.admin-panel-body,
.admin-grid,
.metric-card,
.public-body main,
.public-body section,
.public-body article,
.public-body form {
  min-width: 0 !important;
  max-width: 100% !important;
}

.admin-main .admin-page,
.admin-main > section,
.admin-main > form,
.admin-main > div {
  max-width: min(100%, var(--admin-content-max, 1280px)) !important;
}

.admin-page-header > div,
.admin-panel-header > div,
.panel-head > div,
.metric-card,
.admin-kpi-card,
.public-card,
.record-card,
.project-card {
  min-width: 0 !important;
}

.admin-page-title,
.admin-page-subtitle,
.admin-panel h1,
.admin-panel h2,
.admin-panel h3,
.metric-card strong,
.admin-kpi-card strong,
.public-card strong,
.record-card h2,
.project-card h2 {
  overflow-wrap: break-word !important;
  word-break: normal !important;
}

.admin-actions,
.form-actions,
.inline-actions,
.table-actions,
.review-action-stack,
.bulk-toolbar,
.zip-toolbar,
.inline-import-actions,
.repo-filter-chips,
.hero-ctas,
.pricing-toggle-row,
.docs-article-actions,
.auth-actions {
  flex-wrap: wrap !important;
  min-width: 0 !important;
}

.admin-actions > *,
.form-actions > *,
.inline-actions > *,
.table-actions > *,
.review-action-stack > *,
.bulk-toolbar > *,
.zip-toolbar > * {
  min-width: 0 !important;
}

.form-grid,
.admin-form-grid,
.public-form,
.payment-settings-form,
.webhook-url-grid,
.subscription-choice-form,
.customizer-grid,
.settings-grid,
.filter-main,
.admin-filter-bar,
.advanced-search-form .form-grid-compact {
  min-width: 0 !important;
}

@media (max-width: 1180px) {
  .admin-kpi-grid,
  .analytics-grid,
  .dashboard-grid,
  .report-grid,
  .national-grid,
  .ops-grid,
  .setup-grid,
  .public-card-grid,
  .pricing-tier-grid,
  .pricing-grid,
  .resource-grid,
  .docs-grid,
  .repository-grid,
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .audience-grid,
  .testimonial-grid,
  .grid-4,
  .grid-3,
  .admin-grid-5,
  .admin-grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 900px) {
  .mkt-hero-grid,
  .feature-showcase-grid,
  .workflow-grid,
  .contact-grid,
  .docs-article-section,
  .project-detail-rebuilt,
  .solution-row,
  .verification-grid,
  .submission-checklist-row,
  .access-policy-cards,
  .admin-grid-2,
  .admin-grid-3,
  .admin-kpi-grid,
  .analytics-grid,
  .dashboard-grid,
  .report-grid,
  .national-grid,
  .ops-grid,
  .setup-grid,
  .payment-settings-form,
  .webhook-url-grid,
  .customizer-grid,
  .settings-grid {
    grid-template-columns: 1fr !important;
  }

  .admin-page-header,
  .admin-panel-header,
  .panel-head,
  .subscription-plan-head,
  .message-card-head,
  .inline-import-head,
  .bulk-toolbar,
  .zip-toolbar {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  .admin-page-header .admin-actions,
  .admin-panel-header .admin-actions,
  .panel-head .admin-actions {
    width: 100% !important;
  }

  .admin-page-header .admin-actions .btn,
  .admin-page-header .admin-actions button,
  .admin-panel-header .admin-actions .btn,
  .panel-head .admin-actions .btn {
    flex: 1 1 160px !important;
  }
}

@media (max-width: 760px) {
  body.admin-fullscreen {
    height: auto !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  body.admin-fullscreen .admin-shell {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: auto auto 1fr !important;
    height: auto !important;
    min-height: 100dvh !important;
    overflow: visible !important;
    width: 100% !important;
  }

  body.admin-fullscreen .admin-main {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 12px 12px 92px !important;
  }

  body.admin-fullscreen .admin-topbar {
    position: sticky !important;
    top: 0 !important;
    z-index: 180 !important;
    width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: 44px minmax(0, 1fr) 42px auto !important;
    gap: 8px !important;
    padding: 8px 10px !important;
  }

  body.admin-fullscreen .admin-topbar-title {
    max-width: none !important;
    min-width: 0 !important;
    font-size: 13px !important;
  }

  body.admin-fullscreen .admin-topbar-actions .admin-topbar-action-labeled,
  body.admin-fullscreen .admin-profile-menu,
  body.admin-fullscreen .admin-logout-form {
    display: none !important;
  }

  body.admin-fullscreen .admin-topbar .mkt-nav-logo {
    display: inline-flex !important;
    align-items: center !important;
    flex-shrink: 0 !important;
  }

  .admin-page,
  .dashboard-section,
  .preprint-dashboard-page,
  .preprint-submit-page {
    width: 100% !important;
  }

  .admin-page-title {
    font-size: clamp(23px, 8vw, 30px) !important;
    line-height: 1.12 !important;
  }

  .admin-page-subtitle,
  .admin-panel p,
  .mini-muted {
    font-size: 14px !important;
    line-height: 1.55 !important;
  }

  .admin-grid,
  .admin-grid-2,
  .admin-grid-3,
  .admin-grid-4,
  .admin-grid-5,
  .admin-kpi-grid,
  .analytics-grid,
  .dashboard-grid,
  .report-grid,
  .national-grid,
  .ops-grid,
  .setup-grid,
  .public-card-grid,
  .pricing-tier-grid,
  .pricing-grid,
  .resource-grid,
  .docs-grid,
  .repository-grid,
  .cards-grid,
  .cards-grid-3,
  .cards-grid-3x2,
  .audience-grid,
  .testimonial-grid,
  .grid-2,
  .grid-3,
  .grid-4,
  .form-grid,
  .form-grid-2,
  .admin-form-grid,
  .public-form .form-grid-2,
  .filter-main,
  .admin-filter-bar,
  .advanced-search-form .form-grid-compact,
  .submission-preview dl,
  .access-policy-cards,
  .subscription-choice-form,
  .payment-settings-form,
  .webhook-url-grid,
  .metadata-grid,
  .citation-grid {
    grid-template-columns: 1fr !important;
  }

  .admin-panel,
  .metric-card,
  .admin-kpi-card,
  .public-card,
  .pricing-tier-card,
  .docs-article-card,
  .docs-related-card {
    padding: 16px !important;
  }

  .admin-panel > .panel-head,
  .panel-head,
  .admin-panel-header {
    padding: 14px !important;
  }

  .admin-panel-body,
  .health-list {
    padding: 14px !important;
  }

  .admin-actions .btn,
  .admin-actions button,
  .form-actions .btn,
  .form-actions button,
  .inline-actions .btn,
  .inline-actions button,
  .table-actions .btn,
  .table-actions button,
  .review-action-stack .btn,
  .review-action-stack button {
    width: 100% !important;
    justify-content: center !important;
  }

  .admin-main input:not([type="checkbox"]):not([type="radio"]),
  .admin-main select,
  .admin-main textarea,
  .public-body input:not([type="checkbox"]):not([type="radio"]),
  .public-body select,
  .public-body textarea {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"],
  .admin-main .table-responsive[data-mobile-card="1"] {
    overflow: visible !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] table,
  .admin-main .admin-table-wrap[data-mobile-card="1"] thead,
  .admin-main .admin-table-wrap[data-mobile-card="1"] tbody,
  .admin-main .admin-table-wrap[data-mobile-card="1"] tr,
  .admin-main .admin-table-wrap[data-mobile-card="1"] th,
  .admin-main .admin-table-wrap[data-mobile-card="1"] td,
  .admin-main .table-responsive[data-mobile-card="1"] table,
  .admin-main .table-responsive[data-mobile-card="1"] thead,
  .admin-main .table-responsive[data-mobile-card="1"] tbody,
  .admin-main .table-responsive[data-mobile-card="1"] tr,
  .admin-main .table-responsive[data-mobile-card="1"] th,
  .admin-main .table-responsive[data-mobile-card="1"] td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] table,
  .admin-main .table-responsive[data-mobile-card="1"] table {
    table-layout: auto !important;
    border: 0 !important;
    background: transparent !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] thead,
  .admin-main .table-responsive[data-mobile-card="1"] thead {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] tbody,
  .admin-main .table-responsive[data-mobile-card="1"] tbody {
    display: grid !important;
    gap: 12px !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] tr,
  .admin-main .table-responsive[data-mobile-card="1"] tr {
    display: grid !important;
    gap: 0 !important;
    padding: 12px !important;
    border: 1px solid #dbe7df !important;
    border-radius: var(--inrep-radius, 10px) !important;
    background: #fff !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.05) !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td,
  .admin-main .table-responsive[data-mobile-card="1"] td {
    display: grid !important;
    grid-template-columns: minmax(92px, 38%) minmax(0, 1fr) !important;
    gap: 8px !important;
    align-items: start !important;
    padding: 9px 0 !important;
    border: 0 !important;
    border-bottom: 1px solid #eef2f7 !important;
    background: transparent !important;
    text-align: left !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td:last-child,
  .admin-main .table-responsive[data-mobile-card="1"] td:last-child {
    border-bottom: 0 !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td::before,
  .admin-main .table-responsive[data-mobile-card="1"] td::before {
    content: attr(data-label) !important;
    color: #64756a !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .055em !important;
    line-height: 1.35 !important;
    text-transform: uppercase !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td[data-label=""],
  .admin-main .table-responsive[data-mobile-card="1"] td[data-label=""] {
    grid-template-columns: 1fr !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td[data-label=""]::before,
  .admin-main .table-responsive[data-mobile-card="1"] td[data-label=""]::before {
    display: none !important;
  }

  .admin-mobile-action-bar {
    left: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    width: auto !important;
    max-width: none !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }

  .admin-mobile-action {
    min-width: 0 !important;
  }

  .admin-mobile-action span:not(.admin-count-badge) {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .public-body .container,
  .public-body .section-inner,
  .public-body .docs-article-section,
  .research-shell,
  .pricing-tier-grid,
  .repository-grid,
  .resource-grid,
  .docs-grid,
  .public-card-grid {
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
  }

  .public-body .mkt-section,
  .public-body .cards-section,
  .public-body .page-section {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

@media (max-width: 480px) {
  body.admin-fullscreen .admin-main {
    padding-inline: 10px !important;
  }

  body.admin-fullscreen .admin-topbar {
    grid-template-columns: 42px minmax(0, 1fr) 40px auto !important;
  }

  .admin-main .admin-table-wrap[data-mobile-card="1"] td,
  .admin-main .table-responsive[data-mobile-card="1"] td {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }

  .metric-card strong,
  .admin-kpi-card strong {
    font-size: 28px !important;
  }

  .admin-mobile-action span:not(.admin-count-badge) {
    font-size: 10px !important;
  }

  .public-body .hero-ctas .btn,
  .public-body .hero-ctas a,
  .public-body .cards-section .btn,
  .public-body .final-cta .btn {
    width: 100% !important;
  }
}

/* 2026-05-31: live search suggestions and mobile dashboard audit pass */
.site-search-suggest {
  z-index: 10001 !important;
}
.site-search-suggest button.suggest-item,
.suggest-box button.suggest-item {
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  font: inherit;
}
.site-search-suggest .suggest-item > span,
.suggest-box .suggest-item > span {
  min-width: 0;
}
.site-chatbot-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.site-chatbot-chip-row button {
  border: 1px solid rgba(22, 163, 74, .24);
  border-radius: var(--inrep-radius, 10px) !important;
  background: #f0fdf4;
  color: #166534;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 800;
}

@media (max-width: 760px) {
  .suggest-box,
  .site-search-suggest {
    left: 12px !important;
    right: auto !important;
    width: calc(100vw - 24px) !important;
    max-height: min(46vh, 360px) !important;
    z-index: 10020 !important;
  }

  body.admin-fullscreen .admin-shell {
    display: block !important;
    min-height: 100dvh !important;
  }

  body.admin-fullscreen .admin-topbar {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) auto !important;
    align-items: center !important;
    min-height: 60px !important;
  }

  body.admin-fullscreen .admin-topbar-actions {
    min-width: 0 !important;
    max-width: 132px !important;
    overflow: hidden !important;
    justify-content: flex-end !important;
  }

  body.admin-fullscreen .admin-topbar-actions > *:not(.admin-icon-btn):not([data-command-open]) {
    display: none !important;
  }

  body.admin-fullscreen .admin-search {
    display: none !important;
  }

  body.admin-fullscreen .admin-sidebar {
    position: fixed !important;
    inset: 0 auto 0 0 !important;
    width: min(88vw, 340px) !important;
    max-width: min(88vw, 340px) !important;
    height: 100dvh !important;
    overflow-y: auto !important;
    transform: translateX(-105%) !important;
    z-index: 10010 !important;
    box-shadow: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar {
    transform: translateX(0) !important;
    box-shadow: 20px 0 60px rgba(0, 0, 0, .26) !important;
  }

  body.admin-fullscreen .admin-sidebar-overlay,
  body.admin-fullscreen [data-admin-sidebar-overlay] {
    position: fixed !important;
    inset: 0 !important;
    z-index: 10000 !important;
    background: rgba(2, 20, 12, .42) !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  body.admin-fullscreen.admin-sidebar-open .admin-sidebar-overlay,
  body.admin-fullscreen.admin-sidebar-open [data-admin-sidebar-overlay] {
    display: block !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  body.admin-fullscreen .admin-main {
    padding: 12px 10px calc(92px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .admin-page-header,
  .admin-panel-header,
  .panel-head {
    gap: 12px !important;
  }

  .admin-main .admin-page-header .btn,
  .admin-main .admin-page-header button,
  .admin-main .admin-panel-header .btn,
  .admin-main .admin-panel-header button,
  .admin-main .panel-head .btn,
  .admin-main .panel-head button {
    min-height: 44px !important;
  }

  .admin-main .table-actions,
  .admin-main .inline-actions,
  .admin-main .form-actions,
  .admin-main .admin-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }

  .admin-main .table-actions > *,
  .admin-main .inline-actions > *,
  .admin-main .form-actions > *,
  .admin-main .admin-actions > * {
    width: 100% !important;
  }

  .admin-main table,
  .admin-main pre,
  .admin-main code,
  .admin-main .admin-panel,
  .admin-main .metric-card,
  .admin-main .admin-kpi-card,
  .admin-main .public-card {
    overflow-wrap: anywhere !important;
  }

  .admin-main .admin-table-wrap:not([data-mobile-card="1"]),
  .admin-main .table-responsive:not([data-mobile-card="1"]) {
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

@media (max-width: 520px) {
  .site-chatbot-chip-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  body.admin-fullscreen .admin-topbar-title {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .admin-mobile-action-bar {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

/* ── Dashboard AI Help Chatbot ─────────────────────────────────────────── */
.dash-chatbot {
  position: fixed;
  bottom: 22px;
  right: 22px;
  z-index: 9000;
  font-family: var(--font-body, 'DM Sans', sans-serif);
}
.dash-chatbot-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  background: #08251d;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 28px rgba(8,37,29,.28);
  transition: background .15s;
}
.dash-chatbot-toggle:hover { background: #0f3c2a; }
.dash-chatbot-panel {
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  width: min(360px, calc(100vw - 32px));
  background: #fff;
  border: 1px solid #d4e0da;
  border-radius: 14px;
  box-shadow: 0 20px 58px rgba(8,37,29,.16);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dash-chatbot-panel header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: #08251d;
  color: #fff;
}
.dash-chatbot-panel header strong { font-size: 14px; font-weight: 700; color: #fff; }
.dash-chatbot-panel header button {
  width: 24px; height: 24px;
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 999px;
  background: transparent;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
  display: grid;
  place-items: center;
}
.dash-chatbot-msgs {
  flex: 1;
  overflow-y: auto;
  max-height: 300px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dash-chatbot-msg {
  padding: 10px 13px;
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.55;
  max-width: 90%;
}
.dash-chatbot-msg--bot {
  background: #f3faf6;
  color: #0d2a1e;
  border: 1px solid #d6eadf;
  align-self: flex-start;
}
.dash-chatbot-msg--user {
  background: #08251d;
  color: #fff;
  align-self: flex-end;
}
.dash-chatbot-chip {
  align-self: flex-start;
  padding: 4px 10px;
  border: 1px solid #c5dfd4;
  border-radius: 999px;
  background: #fff;
  color: #0d5c38;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .12s;
}
.dash-chatbot-chip:hover { background: #e8f7ef; }
.dash-chatbot-form {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid #e4ede9;
}
.dash-chatbot-form input {
  flex: 1;
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid #cce0d6;
  border-radius: 8px;
  font-size: 13px;
  color: #0d2a1e;
  background: #f8fbf9;
  outline: none;
}
.dash-chatbot-form input:focus { border-color: #25c75a; box-shadow: 0 0 0 3px rgba(37,199,90,.12); }
.dash-chatbot-form button {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: #25c75a;
  color: #052319;
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .12s;
  flex-shrink: 0;
}
.dash-chatbot-form button:hover { background: #1db04d; }
@media (max-width: 480px) {
  .dash-chatbot { bottom: 14px; right: 14px; }
  .dash-chatbot-panel { width: calc(100vw - 28px); }
}

/* ── Setup page inline edit forms ────────────────────────────────────── */
.setup-inline-edit summary { cursor: pointer; list-style: none; }
.setup-inline-edit summary::-webkit-details-marker { display: none; }
.setup-edit-form {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
  padding: 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: var(--inrep-radius, 10px);
}
.setup-edit-form input {
  flex: 1;
  min-width: 120px;
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 13px;
  background: #fff;
}
.setup-edit-form input:focus { border-color: #25c75a; outline: none; box-shadow: 0 0 0 3px rgba(37,199,90,.1); }
