:root {
  --ink: #0b1628;
  --ink-soft: #31415f;
  --muted: #667085;
  --line: #d9e0ea;
  --surface: #ffffff;
  --surface-alt: #f5f7fb;
  --surface-deep: #e9eef7;
  --navy: #071527;
  --blue: #174a7c;
  --blue-2: #1f6fa8;
  --gold: #b8872f;
  --gold-soft: #f5ead7;
  --success: #1f7a4d;
  --warning: #b76717;
  --danger: #a64040;
  --shadow: 0 20px 50px rgba(8, 22, 42, .12);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --max: 1180px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--surface);
  line-height: 1.55;
  text-rendering: optimizeLegibility;
}
a { color: var(--blue); text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover { color: var(--blue-2); }
img { max-width: 100%; height: auto; display: block; }
:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; }
.skip-link { position: absolute; left: -999px; top: 1rem; background: #fff; color: var(--ink); padding: .75rem 1rem; z-index: 999; }
.skip-link:focus { left: 1rem; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.container { width: min(100% - 40px, var(--max)); margin-inline: auto; }
.narrow { width: min(100% - 40px, 860px); margin-inline: auto; }
.top-bar { background: var(--navy); color: #d8e2ef; font-size: .88rem; }
.top-bar .container { display: flex; justify-content: space-between; gap: 1rem; padding: .55rem 0; flex-wrap: wrap; }
.top-bar a { color: #fff; text-decoration: none; }
.site-header { position: sticky; top: 0; z-index: 90; background: rgba(255,255,255,.96); border-bottom: 1px solid rgba(217,224,234,.86); backdrop-filter: blur(12px); }
.nav-wrap { display: flex; align-items: center; justify-content: space-between; min-height: 78px; gap: 1.5rem; }
.logo { display: inline-flex; align-items: center; gap: .7rem; text-decoration: none; color: var(--ink); font-weight: 800; letter-spacing: -.02em; }
.logo img { width: 180px; height: auto; }
.nav-toggle { display: none; border: 1px solid var(--line); background: #fff; border-radius: 999px; padding: .65rem .85rem; font-weight: 700; }
.site-nav { display: flex; align-items: center; gap: .25rem; }
.site-nav a, .site-nav button { color: var(--ink); background: transparent; border: 0; padding: .75rem .85rem; border-radius: 999px; text-decoration: none; font: inherit; font-weight: 650; cursor: pointer; }
.site-nav a:hover, .site-nav button:hover { background: var(--surface-alt); }
.dropdown { position: relative; }
.dropdown-menu { display: none; position: absolute; right: 0; top: 100%; min-width: 260px; padding: .55rem; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); border-radius: 18px; }
.dropdown:hover .dropdown-menu, .dropdown:focus-within .dropdown-menu { display: grid; }
.dropdown-menu a { border-radius: 12px; padding: .65rem .75rem; }
.header-actions { display: flex; gap: .6rem; align-items: center; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; padding: .85rem 1.08rem; border-radius: 999px; font-weight: 800; border: 1px solid transparent; text-decoration: none; cursor: pointer; min-height: 44px; }
.btn-primary { background: var(--gold); color: #fff; box-shadow: 0 12px 24px rgba(184, 135, 47, .22); }
.btn-primary:hover { color: #fff; background: #9f7427; }
.btn-secondary { border-color: var(--line); color: var(--ink); background: #fff; }
.btn-secondary:hover { background: var(--surface-alt); color: var(--ink); }
.btn-dark { background: var(--navy); color: #fff; }
.btn-dark:hover { color: #fff; background: #11243d; }
.hero { position: relative; overflow: hidden; padding: 92px 0 78px; background: linear-gradient(135deg, #f8fafc 0%, #edf2f8 45%, #fff 100%); }
.hero:before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 75% 18%, rgba(184,135,47,.18), transparent 28%), radial-gradient(circle at 12% 20%, rgba(31,111,168,.10), transparent 24%); pointer-events: none; }
.hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .75fr); gap: 3rem; align-items: center; }
.eyebrow { display: inline-flex; align-items: center; gap: .45rem; color: var(--blue); background: #eaf2f9; border: 1px solid #d7e6f2; padding: .35rem .7rem; border-radius: 999px; font-weight: 800; font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; }
h1, h2, h3 { line-height: 1.08; letter-spacing: -.035em; margin: 0 0 1rem; }
h1 { font-size: clamp(2.6rem, 6vw, 5.15rem); }
h2 { font-size: clamp(2rem, 4.2vw, 3.35rem); }
h3 { font-size: clamp(1.28rem, 2.2vw, 1.65rem); }
p { margin: 0 0 1rem; color: var(--ink-soft); }
.lede { font-size: clamp(1.12rem, 2vw, 1.35rem); color: var(--ink-soft); max-width: 750px; }
.hero-actions { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 1.8rem; }
.hero-panel { background: rgba(255,255,255,.8); border: 1px solid rgba(217,224,234,.9); border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
.hero-panel img { aspect-ratio: 4 / 3; object-fit: cover; width: 100%; }
.panel-body { padding: 1.25rem; }
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; margin-top: 1.5rem; }
.stat { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: .95rem; }
.stat strong { display: block; font-size: 1.45rem; color: var(--ink); }
.section { padding: 78px 0; }
.section-alt { background: var(--surface-alt); }
.section-narrow { padding: 60px 0; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 2rem; margin-bottom: 2rem; }
.section-head p { max-width: 680px; }
.grid { display: grid; gap: 1rem; }
.grid-2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
.grid-5 { grid-template-columns: repeat(5, minmax(0,1fr)); }
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-md); padding: 1.35rem; box-shadow: 0 8px 20px rgba(8,22,42,.045); }
.card-media { padding: 0; overflow: hidden; }
.card-media img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }
.card-media .card-content { padding: 1.35rem; }
.card .icon { width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: var(--gold-soft); color: var(--gold); margin-bottom: .9rem; }
.card .icon svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.85; stroke-linecap: round; stroke-linejoin: round; }
.card h3 { font-size: 1.18rem; letter-spacing: -.02em; }
.kicker { font-weight: 850; color: var(--blue); text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; }
.list-clean { list-style: none; padding: 0; margin: 0; display: grid; gap: .7rem; }
.list-clean li { position: relative; padding-left: 1.45rem; color: var(--ink-soft); }
.list-clean li:before { content: ""; position: absolute; left: 0; top: .6em; width: .5rem; height: .5rem; border-radius: 999px; background: var(--gold); }
.process .card { position: relative; }
.band { background: var(--navy); color: #fff; border-radius: var(--radius-lg); padding: clamp(1.5rem, 5vw, 3rem); display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 1.5rem; align-items: center; }
.band p, .band h2, .band h3 { color: #fff; }
.badge { display: inline-flex; align-items: center; gap: .35rem; padding: .35rem .65rem; border-radius: 999px; background: #eef3f8; border: 1px solid var(--line); color: var(--ink-soft); font-size: .82rem; font-weight: 800; }
.badge-locked { background: #fff4e1; color: #7b4e05; border-color: #efd5a7; }
.badge-good { background: #eaf7f0; color: var(--success); border-color: #c9ead9; }
.badge-warning { background: #fff5e8; color: var(--warning); border-color: #f1d4ad; }
.table-wrap { overflow: visible; border: 1px solid var(--line); border-radius: var(--radius-md); background: #fff; }
table { width: 100%; border-collapse: collapse; table-layout: fixed; min-width: 0; }
th, td { padding: .78rem .72rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; white-space: normal; overflow-wrap: anywhere; word-break: normal; hyphens: auto; }
th { background: var(--surface-alt); color: var(--ink); font-size: .9rem; }
.cta-strip { padding: 55px 0; }
.notice { border-left: 4px solid var(--gold); padding: 1rem 1.2rem; background: #fffaf1; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.legal-block { font-size: .92rem; color: var(--ink-soft); }
.legal-block h2 { font-size: 1.65rem; margin-top: 2.4rem; }
.form-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(1.25rem, 4vw, 2rem); box-shadow: var(--shadow); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.field { display: grid; gap: .35rem; }
label { font-weight: 750; color: var(--ink); }
input, select, textarea { width: 100%; border: 1px solid #cfd8e5; border-radius: 12px; padding: .82rem .9rem; font: inherit; color: var(--ink); background: #fff; }
textarea { min-height: 140px; resize: vertical; }
.checkbox { display: flex; align-items: start; gap: .7rem; }
.checkbox input { width: 1.1rem; height: 1.1rem; margin-top: .22rem; }
.form-message { display: none; margin-top: 1rem; padding: 1rem; border-radius: 14px; background: #eaf7f0; color: var(--success); font-weight: 750; }
.form-message.is-visible { display: block; }
.page-title { padding: 70px 0; background: linear-gradient(135deg, #f7f9fc 0%, #ecf1f7 100%); border-bottom: 1px solid var(--line); }
.breadcrumbs { font-size: .9rem; margin-bottom: 1rem; color: var(--muted); }
.breadcrumbs a { color: var(--muted); text-decoration: none; }
.tool-card { display: flex; flex-direction: column; min-height: 100%; }
.tool-card .btn { margin-top: auto; align-self: start; }
.portal-shell { background: #f4f7fb; min-height: 100vh; }
.portal-grid { display: grid; grid-template-columns: 280px minmax(0,1fr); gap: 1.2rem; }
.portal-side { background: var(--navy); color: #fff; border-radius: var(--radius-lg); padding: 1.2rem; position: sticky; top: 96px; align-self: start; }
.portal-side a { display: block; color: #dbe6f3; text-decoration: none; padding: .7rem .75rem; border-radius: 12px; font-weight: 750; }
.portal-side a:hover, .portal-side a[aria-current="page"] { background: rgba(255,255,255,.1); color: #fff; }
.portal-main { display: grid; gap: 1rem; }
.locked-preview { position: relative; overflow: hidden; }
.locked-preview:after { content: "Preview only"; position: absolute; top: 1rem; right: 1rem; background: rgba(7,21,39,.9); color: #fff; padding: .35rem .7rem; border-radius: 999px; font-size: .78rem; font-weight: 850; }
.blurred { filter: blur(4px); opacity: .78; }
.search-box { display: flex; gap: .7rem; }
.site-footer { background: var(--navy); color: #dbe6f3; padding: 54px 0 28px; }
.footer-grid { display: grid; grid-template-columns: minmax(0,1.2fr) repeat(3, minmax(0,.7fr)); gap: 2rem; margin-bottom: 2rem; }
.site-footer h3 { color: #fff; font-size: 1rem; letter-spacing: 0; }
.site-footer p { color: #dbe6f3; }
.site-footer a { color: #fff; }
.footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: .45rem; }
.footer-legal { border-top: 1px solid rgba(255,255,255,.16); padding-top: 1.4rem; font-size: .86rem; }
.footer-legal p { color: #c9d4e3; margin-bottom: .95rem; }
.footer-logo { width: 160px; margin-bottom: 1rem; }
@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
  .site-nav { position: absolute; left: 20px; right: 20px; top: calc(100% + 8px); display: none; flex-direction: column; align-items: stretch; padding: .7rem; background: #fff; border: 1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow); }
  .site-nav.is-open { display: flex; }
  .site-nav a, .site-nav button { text-align: left; border-radius: 12px; }
  .dropdown-menu { position: static; box-shadow: none; border: 0; background: var(--surface-alt); margin: .25rem 0 .5rem; }
  .header-actions .btn-secondary { display: none; }
  .hero-grid, .grid-2, .grid-3, .grid-4, .grid-5, .footer-grid, .portal-grid, .admin-grid { grid-template-columns: 1fr; }
  .section-head, .band { display: grid; grid-template-columns: 1fr; align-items: start; }
  .portal-side { position: static; }
}
@media (max-width: 680px) {
  .container, .narrow { width: min(100% - 28px, var(--max)); }
  .hero { padding: 64px 0; }
  .section { padding: 56px 0; }
  .form-grid, .stat-grid { grid-template-columns: 1fr; }
  .search-box { display: grid; }
  .logo img { width: 150px; }
}

@media (max-width: 680px) {
  table { font-size: .92rem; }
  th, td { padding: .68rem .55rem; }
}

/* Auth and admin screens */
.auth-shell { min-height: 100vh; display: grid; place-items: center; padding: 2rem; background: linear-gradient(135deg, #f7f9fc 0%, #e8eef6 100%); }
.auth-card { width: min(100%, 480px); background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: clamp(1.4rem, 5vw, 2.2rem); }
.auth-logo { width: 185px; margin-bottom: 1.3rem; }
.small-note { font-size: .88rem; color: var(--muted); }
.portal-header { border-bottom: 1px solid var(--line); }
.check { display: flex; align-items: flex-start; gap: .65rem; font-weight: 650; color: var(--ink-soft); }
.check input { width: 1.1rem; min-width: 1.1rem; height: 1.1rem; margin-top: .2rem; }
.admin-grid { display: grid; grid-template-columns: minmax(280px, .36fr) minmax(0, 1fr); gap: 1.2rem; align-items: start; }
.admin-fieldset { display: grid; gap: .65rem; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 1rem; margin: 1rem 0; }
.admin-fieldset legend { padding: 0 .35rem; font-weight: 850; color: var(--ink); }
.admin-users-card { min-width: 0; }
.admin-users-card .table-wrap { overflow-x: auto; }
.admin-users-card table { min-width: 980px; }
.admin-section-head { margin-bottom: 1rem; }
.admin-inline-field { gap: .2rem; margin-top: .75rem; font-size: .85rem; }
.admin-inline-field input { padding: .62rem .7rem; border-radius: 10px; }
.admin-permission-list { display: grid; gap: .45rem; }


.icon-img { width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center; background: var(--gold-soft); margin-bottom: .9rem; padding: .55rem; }
.icon-img img { width: 100%; height: 100%; object-fit: contain; }
.tool-preview-image { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; background: #f5f7fb; }
.tool-preview-image.contain { object-fit: contain; padding: .7rem; }
.tool-page-card h3 { margin-top: 0; }
.tool-bullets li + li { margin-top: .5rem; }
.access-note { border-left: 4px solid var(--gold); background: #fff9ee; padding: 1rem 1.2rem; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }

.tool-thumb { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: 16px; border: 1px solid var(--line); margin: 0 0 1rem; background: #f5f7fb; }
.tool-thumb.contain { object-fit: contain; padding: .55rem; }
