/* Archway Search — front-end modal
   Brand palette (2019 guidelines): #005C50 teal, #97D2B5 mint, #FEC553 gold.
   Uses a system font stack to blend with the live site. To switch to brand
   fonts, set --archway-font below. */

.archway-overlay,
.archway-trigger,
.archway-menu-search {
	--archway-accent: #005C50;
	--archway-accent-ink: #00443b;
	--archway-mint: #97D2B5;
	--archway-gold: #FEC553;
	--archway-accent-soft: rgba(0,92,80,.10);
	--archway-accent-line: rgba(0,92,80,.26);
	--archway-panel: #ffffff;
	--archway-panel-2: #f5f7f5;
	--archway-ink: #1b2422;
	--archway-ink-soft: #3c4744;
	--archway-muted: #6d756f;
	--archway-line: #e5e9e6;
	--archway-line-soft: #eef1ee;
	--archway-font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ---------------- triggers ---------------- */
.archway-trigger {
	font-family: var(--archway-font);
	display: inline-flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	border: none;
	line-height: 1;
}
.archway-trigger--button {
	padding: 12px 20px;
	font-size: 15px;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(150deg, var(--archway-accent), var(--archway-accent-ink));
	border-radius: 11px;
	box-shadow: 0 10px 22px -12px var(--archway-accent);
	transition: transform .12s, box-shadow .12s;
}
.archway-trigger--button:hover { transform: translateY(-1px); box-shadow: 0 14px 28px -12px var(--archway-accent); }
.archway-trigger--button svg { flex: none; }
.archway-trigger--icon {
	width: 42px; height: 42px;
	justify-content: center;
	color: var(--archway-accent);
	background: var(--archway-panel-2);
	border: 1px solid var(--archway-line);
	border-radius: 11px;
	transition: border-color .15s, color .15s, background .15s;
}
.archway-trigger--icon:hover { border-color: var(--archway-accent-line); background: #fff; }

/* nav-menu search link rendered as an icon button (matches the shortcode icon) */
.archway-menu-search {
	display: inline-flex !important;
	align-items: center; justify-content: center;
	width: 40px !important; height: 40px !important;
	padding: 0 !important;
	margin-left: 16px;
	color: var(--archway-accent) !important;
	background: var(--archway-panel-2) !important;
	border: 1px solid var(--archway-line) !important;
	border-radius: 11px !important;
	box-shadow: none !important;
	line-height: 1 !important;
	vertical-align: middle;
	transition: border-color .15s, color .15s, background .15s;
}
.archway-menu-search:hover { border-color: var(--archway-accent-line) !important; background: #fff !important; }
.archway-menu-search .archway-menu-ico { width: 18px; height: 18px; margin: 0; display: block; }
.archway-menu-search .archway-menu-label { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ---------------- overlay + palette ---------------- */
.archway-overlay {
	position: fixed; inset: 0; z-index: 99999;
	display: flex; align-items: flex-start; justify-content: center;
	padding: 10vh 18px 18px;
	background: rgba(16,28,25,.46);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	font-family: var(--archway-font);
	opacity: 0; transition: opacity .18s ease;
}
.archway-overlay[hidden] { display: none; }
.archway-overlay.archway-open { opacity: 1; }

.archway-palette {
	width: 100%; max-width: 700px;
	display: flex; flex-direction: column; max-height: 76vh;
	background: var(--archway-panel);
	border: 1px solid var(--archway-line);
	border-radius: 16px;
	box-shadow: 0 1px 2px rgba(20,30,28,.06), 0 24px 60px -12px rgba(20,30,28,.34);
	overflow: hidden;
	transform: translateY(-8px) scale(.985);
	transition: transform .18s cubic-bezier(.2,.8,.2,1);
}
.archway-open .archway-palette { transform: translateY(0) scale(1); }

.archway-search-row {
	display: flex; align-items: center; gap: 13px;
	padding: 18px 20px;
	border-bottom: 1px solid var(--archway-line-soft);
	position: relative;
}
.archway-search-row::before {
	content: ""; position: absolute; left: 0; top: 0; right: 0; height: 2px;
	background: linear-gradient(90deg, var(--archway-accent), var(--archway-gold) 90%);
}
.archway-lead-icon { color: var(--archway-accent); flex: none; }
#archway-q {
	flex: 1; border: none; outline: none; background: transparent;
	font-family: var(--archway-font);
	font-size: 19px; font-weight: 500; color: var(--archway-ink);
}
#archway-q::placeholder { color: var(--archway-muted); font-weight: 400; }
.archway-clear {
	border: none; background: var(--archway-panel-2); color: var(--archway-muted);
	width: 26px; height: 26px; border-radius: 7px; cursor: pointer;
	display: grid; place-items: center; flex: none;
}
.archway-clear:hover { color: var(--archway-ink); background: var(--archway-line); }
.archway-clear[hidden] { display: none; }

.archway-results { overflow-y: auto; padding: 6px 0 4px; flex: 1; }
.archway-results::-webkit-scrollbar { width: 10px; }
.archway-results::-webkit-scrollbar-thumb { background: var(--archway-line); border-radius: 8px; border: 3px solid var(--archway-panel); }

.archway-group-head { display: flex; align-items: center; gap: 9px; padding: 13px 20px 7px; }
.archway-group-head .archway-lbl {
	font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--archway-muted);
}
.archway-group-head .archway-cnt {
	font-size: 11px; font-weight: 600; color: var(--archway-muted);
	background: var(--archway-panel-2); border: 1px solid var(--archway-line);
	width: 20px; height: 20px; border-radius: 50%; flex: none;
	display: inline-flex; align-items: center; justify-content: center; line-height: 1;
}
.archway-group-head .archway-rule { flex: 1; height: 1px; background: var(--archway-line-soft); }

.archway-opt {
	display: flex; align-items: flex-start; gap: 14px;
	margin: 0 8px; padding: 11px 12px; border-radius: 11px;
	cursor: pointer; border: 1px solid transparent; position: relative;
	text-decoration: none;
}
.archway-opt .archway-chip,
.archway-opt .archway-avatar { margin-top: 1px; }
.archway-opt .archway-tag { margin-top: 3px; }
.archway-opt .archway-go { margin-top: 10px; }
.archway-opt .archway-chip {
	flex: none; width: 38px; height: 38px; border-radius: 10px;
	display: grid; place-items: center;
}
.archway-opt .archway-chip svg { width: 18px; height: 18px; }
.archway-chip.program { background: rgba(0,92,80,.12); color: var(--archway-accent); }
.archway-chip.event   { background: rgba(254,197,83,.24); color: #946200; }
.archway-chip.staff   { background: rgba(151,210,181,.32); color: #1f6f5c; }
.archway-chip.post    { background: rgba(60,71,68,.10); color: #3c4744; }
.archway-chip.page    { background: rgba(91,103,112,.12); color: #5b6770; }

.archway-opt .archway-avatar {
	flex: none; width: 38px; height: 38px; border-radius: 50%;
	display: grid; place-items: center; font-size: 13.5px; font-weight: 700; color: #fff;
	background-size: cover; background-position: center; overflow: hidden;
}
.archway-opt .archway-body { min-width: 0; flex: 1; display: flex; flex-direction: column; }
.archway-opt .archway-title {
	font-size: 15.5px; font-weight: 600; color: var(--archway-ink); line-height: 1.25; margin: 0;
	display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
	overflow: hidden; overflow-wrap: anywhere;
}
.archway-opt .archway-title mark { background: rgba(254,197,83,.45); color: var(--archway-accent-ink); border-radius: 3px; padding: 0 1px; font-weight: 700; }
.archway-opt .archway-meta {
	font-size: 12.5px; color: var(--archway-muted); margin-top: 1px;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.archway-opt .archway-meta--url { font-size: 12px; color: #8a928c; }
.archway-opt .archway-meta--url .archway-link-ico { vertical-align: -1px; margin-right: 5px; opacity: .75; }
.archway-opt .archway-tag {
	flex: none; font-size: 11px; font-weight: 600; color: var(--archway-muted);
	border: 1px solid var(--archway-line); border-radius: 7px; padding: 3px 9px;
}
.archway-opt .archway-go { flex: none; color: var(--archway-muted); opacity: 0; transition: opacity .12s; display: grid; place-items: center; }

.archway-opt[aria-selected="true"] { background: var(--archway-accent-soft); border-color: var(--archway-accent-line); }
.archway-opt[aria-selected="true"]::before {
	content: ""; position: absolute; left: -8px; top: 8px; bottom: 8px; width: 3px; border-radius: 3px; background: var(--archway-accent);
}
.archway-opt[aria-selected="true"] .archway-go { opacity: 1; color: var(--archway-accent); }
.archway-opt[aria-selected="true"] .archway-tag { border-color: var(--archway-accent-line); color: var(--archway-accent-ink); }

.archway-opt.archway-hidden { display: none; }

.archway-more {
	display: block; width: calc(100% - 16px); margin: 1px 8px 6px;
	text-align: left; padding: 9px 12px 9px 64px;
	background: transparent; border: 1px solid transparent; border-radius: 11px;
	font: inherit; font-size: 12.5px; font-weight: 600; color: var(--archway-accent);
	cursor: pointer;
}
.archway-more:hover { background: var(--archway-accent-soft); }
.archway-more[aria-selected="true"] { background: var(--archway-accent-soft); border-color: var(--archway-accent-line); }

.archway-state { padding: 46px 24px 50px; text-align: center; color: var(--archway-muted); }
.archway-state svg { width: 26px; height: 26px; color: var(--archway-accent); opacity: .5; margin-bottom: 12px; }
.archway-state .archway-big { font-size: 16px; font-weight: 600; color: var(--archway-ink-soft); margin-bottom: 4px; }
.archway-state .archway-sml { font-size: 13.5px; }
.archway-state code { background: var(--archway-panel-2); border: 1px solid var(--archway-line); padding: 1px 6px; border-radius: 5px; color: var(--archway-accent-ink); }

.archway-foot {
	display: flex; align-items: center; gap: 16px;
	padding: 11px 18px; border-top: 1px solid var(--archway-line-soft);
	background: var(--archway-panel-2); font-size: 12px; color: var(--archway-muted);
}
.archway-foot .archway-hint { display: flex; align-items: center; gap: 6px; }
.archway-foot-spacer { flex: 1; }
.archway-foot kbd {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 11px;
	color: var(--archway-muted); background: #fff;
	border: 1px solid var(--archway-line); border-bottom-width: 2px; border-radius: 6px; padding: 2px 6px; line-height: 1;
}

.archway-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

@media (max-width: 560px) {
	.archway-overlay { padding: 6vh 12px 12px; }
}
