/* Override grid z-index so it renders above the dark hero background */
:root { --grid-z: 0; }

a { text-decoration: none; color: inherit; }

/* TOPBAR */
#topbar {
	background:var(--bg);
	border-bottom:1px solid var(--border);
	font-family:var(--mono);
	font-size:0.72rem;
	color:var(--muted);
	position:relative;
	z-index:200;
}

#topbar-inner {
	max-width:var(--w);
	margin:0 auto;
	padding:8px 32px;
	display:flex;
	justify-content:space-between;
	align-items:center;
	gap:16px;
}

#contact-info {
	display:flex;
	gap:20px;
	flex-shrink:0;
	font-size:0.85rem;
}

#contact-info a:hover {
	color:var(--green)
}

/* NAV */
header {
	position:sticky;
	top:0;
	z-index:100;
	background: var(--bg-glass);
	border-bottom:1px solid var(--border);
	backdrop-filter:blur(8px);
}

#navbar {
	max-width:var(--w);
	margin:0 auto;
	padding:0 32px;
	height:64px;
	display:flex;
	align-items:center;
	gap:40px;
}

#logo {
	font-family:var(--mono);
	font-size:1.1rem;
	font-weight:600;
	color:var(--text);
	flex-shrink:0;
	letter-spacing:-0.02em;
}

#logo .accent {
	color:var(--green)
}

#logo .version {
	font-size:0.65rem;
	color:var(--dim);
	margin-left:6px;
	vertical-align:middle;
}

nav {
	display:flex;
	gap:28px;
	margin-right:auto;
}

nav a {
	font-family:var(--mono);
	font-size:0.78rem;
	color:var(--text);
	letter-spacing:0.04em;
	transition:color 0.15s;
	position:relative;
}

nav a:hover {
	color:var(--green)
}

/* HERO BANNER */
#hero-wrap {
	position:relative;
	overflow:hidden;
	border-bottom:1px solid var(--border);
	background:#080a0d;
	/* Force dark palette so text is readable over video regardless of theme */
	--text:      #e8edf5;
	--muted:     #9daab8;
	--dim:       #6c7a8a;
	--bg:        rgba(10,12,16,0.72);
	--bg2:       rgba(10,12,16,0.78);
	--bg3:       rgba(10,12,16,0.84);
	--border:    rgba(255,255,255,0.10);
	--border2:   rgba(255,255,255,0.22);
	--green:     #00d084;
	--green-dim: rgba(0,208,132,0.12);
	--hover-bg:  rgba(255,255,255,0.05);
}

/* Gradient: solid dark over text area, fades in at the video edge */
#hero-wrap::after {
	content:'';
	position:absolute;
	inset:0;
	background:linear-gradient(
		to right,
		rgba(8,10,14,1)    0%,
		rgba(8,10,14,1)    44%,
		rgba(8,10,14,0.75) 56%,
		rgba(8,10,14,0.15) 72%,
		rgba(8,10,14,0)    100%
	);
	z-index:2;
	pointer-events:none;
}

#hero {
	position:relative;
	z-index:3;
	max-width:var(--w);
	margin:0 auto;
	padding:100px 32px 80px 16px;
	display:block;
}

#hero > div {
	max-width:600px;
}

#hero h1 {
	font-family:var(--sans);
	font-weight:300;
	font-size:clamp(2.4rem,3.5vw,4rem);
	line-height:1.1;
	letter-spacing:-0.02em;
	color:var(--text);
	margin-bottom:24px;
}

#hero h1 strong {
	font-weight:600;
}
#hero h1 .hl {
	color:var(--green);
	font-weight:600;
}

.hero-desc {
	font-size:1rem;
	line-height:1.8;
	color:var(--muted);
	margin-bottom:36px;
	max-width:520px;
}

.hero-actions {
	display:flex;
	gap:12px;
	margin-bottom:48px;
	flex-wrap:wrap;
}

.spec-table {
	background:var(--bg);
	font-family:var(--mono);
	font-size:0.9rem;
	border:1px solid var(--border);
	border-radius:4px;
	overflow:hidden;
	backdrop-filter:blur(6px);
}

.spec-row {
	display:flex;
	align-items:center;
	border-bottom:1px solid var(--border);
	padding:10px 16px;
	gap:12px;
	transition:background 0.15s;
}

.spec-row:last-child {
	border-bottom:none;
}
.spec-row:hover {
	background:var(--bg2);
}
.spec-key {
	color:var(--dim);
	width:200px;
	flex-shrink:0;
}

.spec-key::after {
	content:":";
}
.spec-val {
	color:var(--green);
	flex:1;
}

.spec-badge {
	font-size:0.65rem;
	padding:2px 7px;
	border-radius:2px;
	background:var(--green-dim);
	color:var(--green);
	border:1px solid rgba(0,208,132,0.25);
}

.spec-badge.amber {
	background:var(--amber-dim);
	color:var(--amber);
	border-color:rgba(245,166,35,0.25);
}


.video-wrap {
	position:relative;
	background:#080a0d;
}

#video {
	display:block;
	width:100%;
	height:440px;
	object-fit:cover;
}

#clip-wrap {
	position:absolute;
	left:42%;
	right:0;
	top:0;
	bottom:0;
	overflow:hidden;
	z-index:1;
}

#clip-nav {
	display:flex;
	gap:7px;
	align-items:center;
}

.clip-dot {
	width:7px;
	height:7px;
	border-radius:50%;
	background:rgba(255,255,255,0.3);
	border:none;
	cursor:pointer;
	padding:0;
	transition:background 0.3s, transform 0.2s;
}

.clip-dot:hover {
	background:rgba(255,255,255,0.6);
	transform:scale(1.2);
}

.clip-dot.active {
	background:var(--green);
	transform:scale(1.1);
}

.video-placeholder {
	width:100%;
	height:440px;
	background:#080a0d;
	display:flex;
	flex-direction:column;
	align-items:center;
	justify-content:center;
	gap:12px;
}

.video-placeholder svg {
	opacity:0.15;
}
.video-placeholder p {
	font-family:var(--mono);
	font-size:0.72rem;
	color:var(--dim);
}

/* BANNER STATS BAR */
#banner-stats {
	position:relative;
	z-index:3;
	display:grid;
	grid-template-columns:1fr 1fr 1fr auto;
	border-top:1px solid rgba(255,255,255,0.10);
	font-family:var(--mono);
	backdrop-filter:blur(6px);
	background:rgba(8,10,14,0.60);
}

#banner-stats .panel-stat {
	padding:14px 32px;
	border-right:1px solid rgba(255,255,255,0.10);
	display:flex;
	flex-direction:column;
	gap:3px;
}

#banner-stats .panel-stat:last-child {
	border-right:none;
}

#banner-clips {
	justify-content:center;
	align-items:center;
	flex-direction:row;
	padding:14px 24px;
}

.panel-stat-val {
	font-size:1.3rem;
	font-weight:600;
	color:#00d084;
	line-height:1;
}

.panel-stat-lbl {
	font-size:0.65rem;
	color:rgba(255,255,255,0.4);
	text-transform:uppercase;
	letter-spacing:0.06em;
}


/* SECTION SHARED */
section {
	position:relative;
}

.section-wrap {
	max-width:var(--w);
	margin:0 auto;
	padding:80px 32px;
}

.section-header {
	margin-bottom:56px;
}
.sec-label {
	font-family:var(--mono);
	font-size:0.72rem;
	color:var(--green);
	letter-spacing:0.08em;
	margin-bottom:12px;
	display:flex;
	align-items:center;
	gap:8px;
}

.sec-label::before {
	content:"";
	width:16px;
	height:1px;
	background:var(--green);
}

.sec-title {
	font-family:var(--sans);
	font-weight:300;
	font-size:clamp(1.8rem,2.5vw,2.6rem);
	letter-spacing:-0.02em;
	color:var(--text);
	line-height:1.15;
}

.sec-title strong {
	font-weight:600;
}
.sec-desc {
	font-size:0.95rem;
	color:var(--muted);
	line-height:1.8;
	margin-top:12px;
	max-width:580px;
}


/* SERVICES */
#services, #capabilities {
	background:var(--bg2);
	border-top:1px solid var(--border);
	border-bottom:1px solid var(--border);
}

/* Shared bordered 3-column grid (services, process, testimonials) */
.panel-grid {
	display:grid;
	grid-template-columns:repeat(3,1fr);
	gap:1px;
	background:var(--border);
	border:1px solid var(--border);
	border-radius:6px;
	overflow:hidden;
}

.svc-card {
	background:var(--bg2);
	padding:36px 32px;
	transition:background 0.2s;
	position:relative;
}

.svc-card:hover {
	background:var(--surface);
}
.svc-card.primary {
	background:var(--bg3);
}

.svc-card.primary>p {
	color:var(--dim);
}

.svc-card.primary:hover {
	background:var(--surface2);
}

.svc-card h3 {
	font-family:var(--sans);
	font-weight:600;
	font-size:1.1rem;
	color:var(--text);
	margin-bottom:10px;
}

.svc-card>p {
	font-size:0.9rem;
	color:var(--muted);
	line-height:1.75;
	margin-bottom:28px;
}

.svc-list {
	list-style:none;
	display:flex;
	flex-direction:column;
	gap:8px;
	margin-bottom:32px;
}

.svc-list li {
	font-size:0.87rem;
	color:var(--muted);
	display:flex;
	align-items:baseline;
	gap:8px;
}

.svc-list li::before {
	content:"→";
	color:var(--green);
	flex-shrink:0;
	font-size:0.7rem;
}

.svc-card.primary .svc-list li {
	color:var(--text)
}
.tag-row {
	display:flex;
	gap:6px;
	flex-wrap:wrap;
	position: absolute;
	bottom: 1.5rem;
}

.tag {
	font-family:var(--mono);
	font-size:0.65rem;
	padding:3px 8px;
	border-radius:2px;
	background:var(--green-dim);
	border:1px solid rgba(0,208,132,0.25);
	color:var(--green);
	font-weight:bold;
}

/* PROCESS */
.process-grid {
	margin-top:56px;
}

.proc-step {
	background:var(--bg);
	padding:32px 28px;
	transition:background 0.2s;
}

.proc-step:hover {
	background:var(--bg2);
}

.caption {
	font-family:var(--mono);
	font-size:0.65rem;
	color:var(--green);
	margin-bottom:20px;
	letter-spacing:0.05em;
}

.proc-step h4 {
	font-weight:600;
	font-size:0.95rem;
	color:var(--text);
	margin-bottom:10px;
}

.proc-step p {
	font-size:0.87rem;
	color:var(--muted);
	line-height:1.7;
	margin-bottom:20px;
}

.proc-meta {
	font-family:var(--mono);
	font-size:0.68rem;
	color:var(--dim);
}

.proc-meta span {
	color:var(--amber);
}

/* CAPABILITIES */

.cap-grid {
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:64px;
	align-items:start;
}

.cap-table-wrap {
	border:1px solid var(--border);
	border-radius:6px;
	overflow:hidden;
	font-family:var(--mono);
	font-size:0.78rem;
}

.cap-table-head {
	display:grid;
	grid-template-columns:1fr 80px 60px;
	gap:12px;
	padding:10px 16px;
	background:var(--bg3);
	border-bottom:1px solid var(--border);
	color:var(--dim);
	font-size:0.65rem;
	text-transform:uppercase;
	letter-spacing:0.07em;
}

.cap-row {
	display:grid;
	grid-template-columns:1fr 80px 60px;
	gap:12px;
	padding:12px 16px;
	border-bottom:1px solid var(--border);
	align-items:center;
	transition:background 0.15s;
}

.cap-row:last-child {
	border-bottom:none;
}
.cap-row:hover {
	background:var(--bg3);
}
.cap-name {
	color:var(--text);
}
.cap-bar-wrap {
	height:4px;
	background:rgba(0,0,0,0.08);
	border-radius:2px;
	overflow:hidden;
}
[data-theme="dark"] .cap-bar-wrap {
	background:rgba(255,255,255,0.08);
}

.cap-bar {
	height:100%;
	border-radius:2px;
	background:var(--green);
	transform-origin:left;
	transition:transform 1s ease;
}

.cap-pct {
	color:var(--green);
	font-size:0.7rem;
	text-align:right;
}

.why-list {
	display:flex;
	flex-direction:column;
	gap:0;
	border:1px solid var(--border);
	border-radius:6px;
	overflow:hidden;
}

.why-item {
	display:flex;
	gap:20px;
	padding:24px;
	border-bottom:1px solid var(--border);
	transition:background 0.15s;
}

.why-item:last-child {
	border-bottom:none;
}
.why-item:hover {
	background:var(--bg3);
}
.why-icon {
	font-family:var(--mono);
	font-size:0.72rem;
	color:var(--green);
	flex-shrink:0;
	padding-top:3px;
	width:28px;
}

.why-item h4 {
	font-weight:600;
	font-size:0.92rem;
	color:var(--text);
	margin-bottom:6px;
}

.why-item p {
	font-size:0.87rem;
	color:var(--muted);
	line-height:1.7;
}


/* TESTIMONIALS */
.trust-grid {
	margin-top:56px;
}

.trust-card {
	background:var(--bg);
	padding:32px 28px;
	transition:background 0.15s;
}

.trust-card:hover {
	background:var(--bg2);
}

.trust-card blockquote {
	font-size:0.9rem;
	line-height:1.75;
	color:var(--muted);
	margin-bottom:24px;
	font-style:normal;
}

.trust-author {
	display:flex;
	flex-direction:column;
	gap:3px;
	padding-top:20px;
	border-top:1px solid var(--border);
}

.trust-author strong {
	font-family:var(--mono);
	font-size:0.78rem;
	color:var(--text);
	font-weight:500;
}

.trust-author span {
	font-family:var(--mono);
	font-size:0.7rem;
	color:var(--dim);
}

/* CTA */
#cta {
	background:var(--bg2);
	border-top:1px solid var(--border);
}

.cta-inner {
	display:grid;
	grid-template-columns:1fr 1fr;
	gap:80px;
	align-items:center;
}

.cta-title {
	font-family:var(--sans);
	font-weight:300;
	font-size:2.2rem;
	letter-spacing:-0.02em;
	color:var(--text);
	line-height:1.15;
	margin-bottom:16px;
}

.cta-title strong {
	font-weight:600;
}
.cta-desc {
	font-size:0.95rem;
	color:var(--muted);
	line-height:1.8;
	margin-bottom:32px;
}

.cta-actions {
	display:flex;
	gap:12px;
	flex-wrap:wrap;
}

.cta-aside {
	background:var(--bg);
	border:1px solid var(--border2);
	border-radius:6px;
	overflow:hidden;
	font-family:var(--mono);
	font-size:0.78rem;
}

.cta-aside-head {
	padding:12px 16px;
	background:var(--bg2);
	border-bottom:1px solid var(--border);
	color:var(--dim);
	font-size:0.65rem;
}

.cta-aside-row {
	display:flex;
	justify-content:space-between;
	align-items:center;
	padding:12px 16px;
	border-bottom:1px solid var(--border);
	gap:16px;
}

.cta-aside-row:last-child {
	border-bottom:none;
}
.cta-aside-row .k {
	color:var(--dim);
}
.cta-aside-row .v {
	color:var(--text);
}
.cta-aside-row .v.green {
	color:var(--green);
}
.cta-aside-row .v.amber {
	color:var(--amber);
}

/* FOOTER */
footer {
	background:var(--bg);
	border-top:1px solid var(--border);
	padding:60px 32px 32px;
	position:relative;
}

#footer-inner {
	max-width:var(--w);
	margin:0 auto;
}

#footer-top {
	display:grid;
	grid-template-columns:1.6fr 1fr 1fr 1fr;
	gap:64px;
	margin-bottom:48px;
}

.footer-logo {
	font-family:var(--mono);
	font-size:1rem;
	font-weight:600;
	color:var(--text);
	margin-bottom:12px;
}

.footer-logo .accent {
	color:var(--green);
}
.footer-brand p {
	font-size:0.87rem;
	color:var(--dim);
	line-height:1.75;
}

.footer-col h5 {
	font-family:var(--mono);
	font-size:0.65rem;
	font-weight:500;
	text-transform:uppercase;
	letter-spacing:0.10em;
	color:var(--muted);
	margin-bottom:16px;
}

.footer-col a {
	display:block;
	font-size:0.87rem;
	color:var(--dim);
	margin-bottom:10px;
	transition:color 0.15s;
}

.footer-col a:hover {
	color:var(--green);
}
#footer-bottom {
	border-top:1px solid var(--border);
	padding-top:24px;
	display:flex;
	justify-content:space-between;
	align-items:center;
	font-family:var(--mono);
	font-size:0.7rem;
	color:var(--dim);
	gap:16px;
	flex-wrap:wrap;
}

.status-dot {
	display:inline-flex;
	align-items:center;
	gap:6px;
	color:var(--green);
}

.status-dot::before {
	content:"";
	width:6px;
	height:6px;
	border-radius:50%;
	background:var(--green);
	flex-shrink:0;
}

/* RESPONSIVE */
@media(max-width:1024px){
	.panel-grid {
		grid-template-columns:1fr;
	}
	.process-grid {
		grid-template-columns:1fr 1fr;
	}
	.cap-grid {
		grid-template-columns:1fr;
	}
	.cta-inner {
		grid-template-columns:1fr;
	}
	#footer-top {
		grid-template-columns:1fr 1fr;
		gap:40px;
	}
}
@media(max-width:768px){
	.section-wrap {
		padding:56px 20px;
	}
	#hero {
		padding:56px 20px 48px;
	}
	#hero > div {
		max-width:none;
	}
	/* Full-coverage overlay on narrow screens */
	#clip-wrap {
		left:0;
	}
	#hero-wrap::after {
		background:rgba(8,10,14,0.88);
	}
	#hero h1 {
		font-size:2.4rem;
	}
	.hero-actions {
		flex-direction:column;
	}
	.btn-cta,.btn-outline {
		text-align:center;
	}
	#banner-stats {
		grid-template-columns:1fr 1fr 1fr;
	}
	#banner-clips {
		display:none;
	}
	#topbar {
		display:none;
	}
	nav {
		display:none;
	}
	#logo {
		margin-right: auto;
	}
	#footer-top {
		grid-template-columns:1fr;
		gap:32px;
	}
	.cta-aside {
		display:none;
	}
}

/* ═══════════════════════════════════════════════════════════
   ENQUIRY MODAL  —  index.html
═══════════════════════════════════════════════════════════ */

.modal-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.6);
	backdrop-filter: blur(4px);
	z-index: 1000;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 20px;
}
.modal-overlay.open { display: flex; }

.modal {
	background: var(--bg2);
	border: 1px solid var(--border2);
	border-radius: 6px;
	width: 100%;
	max-width: 600px;
	max-height: 92vh;
	overflow-y: auto;
	padding: 32px;
	position: relative;
}

.modal-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
}

.modal-close {
	background: transparent;
	border: none;
	color: var(--dim);
	font-size: 1.5rem;
	cursor: pointer;
	line-height: 1;
	padding: 0 4px;
	transition: color 0.15s;
}
.modal-close:hover { color: var(--text); }

.modal-intro {
	font-size: 0.83rem;
	color: var(--muted);
	margin-bottom: 24px;
	line-height: 1.65;
	border-left: 3px solid var(--green);
	padding-left: 12px;
}

.modal-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 20px;
	gap: 12px;
}

.req-note {
	font-family: var(--mono);
	font-size: 0.72rem;
	color: var(--dim);
}

.file-drop {
	border: 2px dashed var(--border-dashed);
	border-radius: 3px;
	padding: 18px 16px;
	text-align: center;
	cursor: pointer;
	position: relative;
	transition: border-color 0.15s, background 0.15s;
	font-size: 0.82rem;
	color: var(--muted);
}
.file-drop:hover { border-color: var(--green); background: var(--green-dim); }

.file-drop input[type="file"] {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
	width: 100%;
	height: 100%;
	font-size: 0;
}

.upload-quota {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
}
.upload-quota-bar {
	flex: 1;
	height: 4px;
	background: var(--border2);
	border-radius: 2px;
	overflow: hidden;
}
.upload-quota-fill {
	height: 100%;
	background: var(--green);
	border-radius: 2px;
	transition: width 0.2s ease, background 0.2s ease;
}
.upload-quota-fill.warn { background: #d97706; }
.upload-quota-fill.over { background: #e05252; }
.upload-quota-text {
	font-family: var(--mono);
	font-size: 0.68rem;
	color: var(--dim);
	white-space: nowrap;
}

#file-list {
	list-style: none;
	margin-top: 6px;
}
#file-list li {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--mono);
	font-size: 0.72rem;
	color: var(--dim);
	padding: 4px 0;
	border-bottom: 1px solid var(--border);
}
#file-list li::before { content: "↳ "; color: var(--green); flex-shrink: 0; }
.file-item-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-item-size { color: var(--muted); flex-shrink: 0; }
.file-remove {
	background: transparent;
	border: none;
	color: var(--dim);
	cursor: pointer;
	font-size: 1rem;
	line-height: 1;
	padding: 0 2px;
	flex-shrink: 0;
	transition: color 0.15s;
}
.file-remove:hover { color: #e05252; }

.enquiry-success {
	text-align: center;
	padding: 24px 0 8px;
}
.success-icon {
	font-size: 2.5rem;
	color: var(--green);
	margin-bottom: 12px;
	font-family: var(--mono);
}
.enquiry-success h3 { margin-bottom: 12px; font-size: 1.1rem; }
.enquiry-success p {
	color: var(--muted);
	font-size: 0.85rem;
	margin-bottom: 24px;
	line-height: 1.65;
}

/* ═══════════════════════════════════════════════════════════
   LEGAL DOCUMENTS  —  terms.html / nda.html
═══════════════════════════════════════════════════════════ */

.legal-doc-wrap {
	max-width: 860px;
	margin: 60px auto 80px;
	padding: 0 24px;
}

.legal-doc-header {
	margin-bottom: 40px;
	border-bottom: 1px solid var(--border2);
	padding-bottom: 28px;
}

.legal-doc-header h1 {
	font-family: var(--sans);
	font-size: 1.8rem;
	font-weight: 600;
	margin: 10px 0 12px;
	line-height: 1.2;
}

.legal-meta {
	font-family: var(--mono);
	font-size: 0.72rem;
	color: var(--dim);
	letter-spacing: 0.02em;
}

.legal-intro-box {
	background: var(--green-dim);
	border-left: 3px solid var(--green);
	border-radius: 0 3px 3px 0;
	padding: 14px 18px;
	margin-bottom: 32px;
	font-size: 0.88rem;
	color: var(--muted);
	line-height: 1.65;
}

.legal-toc {
	background: var(--bg2);
	border: 1px solid var(--border);
	border-radius: 4px;
	padding: 18px 22px;
	margin-bottom: 48px;
}

.legal-toc ol {
	margin: 10px 0 0 18px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4px 24px;
}

@media (max-width: 560px) {
	.legal-toc ol { grid-template-columns: 1fr; }
}

.legal-toc ol li {
	font-family: var(--mono);
	font-size: 0.75rem;
}

.legal-toc a { color: var(--muted); }
.legal-toc a:hover { color: var(--green); text-decoration: underline; }

.legal-doc section {
	margin-bottom: 44px;
	scroll-margin-top: 80px;
}

.legal-doc section h2 {
	font-family: var(--mono);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green);
	margin-bottom: 18px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--border);
}

.legal-doc section p {
	font-size: 0.88rem;
	line-height: 1.75;
	color: var(--text);
	margin-bottom: 12px;
}

.legal-doc section ol { margin: 4px 0 14px 22px; }

.legal-doc section ol li {
	font-size: 0.88rem;
	line-height: 1.75;
	color: var(--text);
	margin-bottom: 4px;
}

.legal-doc section strong { color: var(--text); font-weight: 600; }

.legal-defs {
	width: 100%;
	border-collapse: collapse;
	margin: 4px 0 18px;
	font-size: 0.85rem;
}

.legal-defs td {
	padding: 8px 12px;
	vertical-align: top;
	border-bottom: 1px solid var(--border);
	line-height: 1.65;
	color: var(--text);
}

.legal-defs td:first-child {
	white-space: nowrap;
	padding-right: 20px;
	font-family: var(--mono);
	font-size: 0.78rem;
	color: var(--muted);
	width: 220px;
}

.legal-defs tr:last-child td { border-bottom: none; }

.legal-footer-note {
	margin-top: 56px;
	padding-top: 24px;
	border-top: 1px solid var(--border2);
	font-size: 0.8rem;
	color: var(--dim);
	line-height: 1.7;
}

.legal-footer-note p { margin-bottom: 6px; }

.legal-footer-note a { color: var(--green); }
.legal-footer-note a:hover { text-decoration: underline; }

/* Footer links */
#footer-bottom a { opacity: 0.75; transition: opacity 0.15s; }
#footer-bottom a:hover { opacity: 1; }

/* ═══════════════════════════════════════════════════════════
   ENHANCEMENTS
═══════════════════════════════════════════════════════════ */

/* ── Fix: svc-card bottom padding for absolute tag-row ── */
.svc-card { padding-bottom: 68px; }

/* ── Featured service card top accent ──────────────────── */
.svc-card.primary {
	border-top: 2px solid var(--green);
	margin-top: -2px; /* keep grid flush */
}

/* ── Header scroll shadow ───────────────────────────────── */
header.scrolled {
	border-bottom-color: var(--border2);
	box-shadow: 0 1px 18px rgba(0,0,0,0.08);
}
[data-theme="dark"] header.scrolled {
	box-shadow: 0 1px 18px rgba(0,0,0,0.28);
}

/* ── Nav active state (scrollspy) ───────────────────────── */
nav a.active { color: var(--green); }

/* ── Scroll-reveal ──────────────────────────────────────── */
.reveal {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.55s ease, transform 0.55s ease;
}
.reveal.in {
	opacity: 1;
	transform: none;
}

/* ── Blockquote opening mark ────────────────────────────── */
.trust-card blockquote {
	position: relative;
	padding-top: 40px;
}
.trust-card blockquote::before {
	content: '\201C';
	position: absolute;
	top: -6px;
	left: -4px;
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 4.5rem;
	line-height: 1;
	color: var(--green);
	opacity: 0.20;
	pointer-events: none;
}

/* ── Topbar tagline truncation (medium viewports) ────────── */
#tagline {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	min-width: 0;
}

/* ── Portal Mockups ──────────────────────────────────────── */
.portal-showcase {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	margin-top: 56px;
}
@media (max-width: 860px) { .portal-showcase { grid-template-columns: 1fr; } }

.pm-card {
	background: var(--bg2);
	border: 2px solid var(--border2);
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.pm-label {
	font-family: var(--mono);
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--text);
	font-weight: 600;
	padding: 13px 16px;
	border-bottom: 2px solid var(--green);
	background: var(--bg3);
}
.pm-frame {
	padding: 20px;
	font-size: 0.76rem;
	pointer-events: none;
	user-select: none;
	overflow: hidden;
}
.pm-panel {
	background: var(--bg);
	border: 1px solid var(--border2);
	border-radius: 4px;
	margin-bottom: 8px;
	overflow: hidden;
}
.pm-panel--green { border-color: var(--green); }
.pm-panel-head {
	font-weight: 700;
	color: var(--text);
	padding: 10px 14px;
	background: var(--bg2);
	border-bottom: 2px solid var(--border2);
	font-size: 1em;
}
.pm-panel-head--green { background: var(--green-dim); color: var(--green); }
.pm-panel-body { padding: 10px 12px; }
.pm-kv {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 4px 0;
	border-bottom: 1px solid var(--border);
	gap: 8px;
}
.pm-kv:last-child { border-bottom: none; }
.pm-kv-k { color: var(--muted); flex-shrink: 0; }
.pm-kv-v { font-family: var(--mono); color: var(--text); text-align: right; }
.pm-pill {
	display: inline-block;
	font-family: var(--mono);
	font-size: 0.85em;
	padding: 2px 7px;
	border-radius: 3px;
	border: 1px solid;
	white-space: nowrap;
}
.pm-pill--green { color: var(--green); border-color: var(--green); background: var(--green-dim); }
.pm-pill--amber { color: var(--amber); border-color: var(--amber); background: var(--amber-dim); }
.pm-pill--grey  { color: var(--dim); border-color: var(--border2); }
.pm-bic { font-family: var(--mono); font-size: 0.85em; white-space: nowrap; }
.pm-bic--us     { color: var(--dim); }
.pm-bic--client { color: var(--amber); }
.pm-table { width: 100%; border-collapse: collapse; }
.pm-table th {
	font-family: var(--mono);
	font-size: 0.8em;
	color: var(--dim);
	text-align: left;
	padding: 5px 8px;
	border-bottom: 1px solid var(--border2);
	letter-spacing: 0.04em;
}
.pm-table td { padding: 5px 8px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.pm-table tr:last-child td { border-bottom: none; }
.pm-ref {
	font-family: var(--mono);
	font-size: 0.8em;
	background: var(--bg3);
	border: 1px solid var(--border2);
	border-radius: 3px;
	padding: 1px 5px;
	color: var(--dim);
	white-space: nowrap;
}
.pm-stats {
	display: flex;
	border: 1px solid var(--border2);
	border-radius: 4px;
	margin-bottom: 8px;
	overflow: hidden;
}
.pm-stat { flex: 1; padding: 8px 10px; border-right: 1px solid var(--border2); }
.pm-stat:last-child { border-right: none; }
.pm-stat-val { font-size: 1.5em; font-weight: 700; color: var(--green); display: block; line-height: 1.1; }
.pm-stat-lbl { font-family: var(--mono); font-size: 0.7em; color: var(--dim); }
.pm-stat--amber { background: var(--amber-dim); }
.pm-stat--amber .pm-stat-val { color: var(--amber); }
.pm-thread { display: flex; flex-direction: column; gap: 5px; }
.pm-msg { padding: 7px 10px; border-radius: 3px; line-height: 1.45; }
.pm-msg--inbound  { background: var(--bg); border: 1px solid var(--border2); }
.pm-msg--outbound { background: var(--green-dim); border-left: 3px solid var(--green); border-top: 1px solid var(--border2); border-right: 1px solid var(--border2); border-bottom: 1px solid var(--border2); }
.pm-msg-meta { font-family: var(--mono); font-size: 0.75em; color: var(--dim); margin-bottom: 3px; }
.pm-file { display: flex; justify-content: space-between; gap: 8px; padding: 4px 0; border-bottom: 1px solid var(--border); font-family: var(--mono); font-size: 0.85em; }
.pm-file:last-child { border-bottom: none; }
.pm-file-name { color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pm-file-date { color: var(--dim); flex-shrink: 0; }
.pm-tracker { display: flex; align-items: flex-start; padding: 10px 0 8px; }
.pm-step { display: flex; flex-direction: column; align-items: center; flex: 1; position: relative; }
.pm-step::before { content: ''; position: absolute; top: 5px; right: 50%; width: 100%; height: 1px; background: var(--border2); z-index: 0; }
.pm-step:first-child::before { display: none; }
.pm-dot { width: 11px; height: 11px; border-radius: 50%; background: var(--border2); border: 2px solid var(--border2); position: relative; z-index: 1; margin-bottom: 4px; flex-shrink: 0; }
.pm-dot--done   { background: var(--green); border-color: var(--green); }
.pm-dot--active { background: var(--bg); border-color: var(--green); border-width: 3px; }
.pm-step-lbl { font-family: var(--mono); font-size: 0.6em; color: var(--dim); text-align: center; line-height: 1.2; }
.pm-step--active .pm-step-lbl { color: var(--green); font-weight: 600; }
.pm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.pm-quote-amount { font-size: 1.7em; font-weight: 700; color: var(--green); font-family: var(--mono); margin: 6px 0 8px; }
.pm-compose { margin-top: 8px; border: 1px solid var(--border2); border-radius: 3px; padding: 8px 10px; color: var(--dim); font-family: var(--mono); font-size: 0.85em; background: var(--bg); }

/* tracker green connecting line for done/active steps */
.pm-step--done::before,
.pm-step--active::before { background: var(--green); }
/* white inner frame so stat cards and table rows appear white */
.pm-frame { background: var(--bg); }
