/* ============================================================
   WRC Widgets
   Styles for the four custom widgets. Tokens live in wrc-base.css.
   ============================================================ */


/* ---------- Floating Mini-Nav ---------- */

.wrc-mininav {
	position: fixed;
	bottom: 28px;
	left: 0;
	right: 0;
	display: flex;
	justify-content: center;
	pointer-events: none;
	z-index: 60;
}

.wrc-mininav__pill {
	pointer-events: auto;
	display: flex;
	align-items: center;
	background: var(--wrc-ink);
	color: #fff;
	border-radius: var(--r-pill);
	padding: 8px;
	box-shadow: var(--shadow-floating);
	transition: all 0.45s cubic-bezier(0.22, 0.8, 0.32, 1);
	max-width: calc(100vw - 32px);
}

/* Side panels (menu on left, crisis phones on right) */
.wrc-mininav__panel {
	display: flex;
	align-items: center;
	max-width: 0;
	opacity: 0;
	overflow: hidden;
	transition: max-width 0.45s cubic-bezier(0.22, 0.8, 0.32, 1), opacity 0.3s ease;
}
.wrc-mininav__panel.is-open { opacity: 1; }
.wrc-mininav__panel--menu.is-open   { max-width: 720px; }
.wrc-mininav__panel--crisis.is-open { max-width: 560px; }

.wrc-mininav__menu {
	display: flex;
	align-items: center;
	gap: 4px;
	padding-left: 12px;
	padding-right: 16px;
	white-space: nowrap;
}
.wrc-mininav__menu-item {
	color: #fff;
	padding: 8px 14px;
	border-radius: var(--r-pill);
	font-size: 13px;
	font-weight: 500;
	background: transparent;
}
.wrc-mininav__menu-item.is-current { background: rgba(255, 255, 255, 0.14); }

.wrc-mininav__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: inherit;
	cursor: pointer;
	border: none;
}

.wrc-mininav__btn--menu {
	width: 44px;
	height: 44px;
	border-radius: 999px;
	background: #fff;
	color: var(--wrc-ink);
	transition: transform 0.3s;
}
.wrc-mininav__btn--menu[aria-expanded="true"] { transform: rotate(90deg); }

.wrc-mininav__quick-exit {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-left: 8px;
	padding: 10px 16px;
	border-radius: var(--r-pill);
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.18);
	font-size: 13px;
	font-weight: 500;
}

.wrc-mininav__btn--crisis {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-left: 6px;
	margin-right: 4px;
	padding: 10px 18px;
	border-radius: var(--r-pill);
	background: var(--wrc-gradient);
	color: #fff;
	font-size: 13px;
	font-weight: 600;
	box-shadow: var(--shadow-cta);
}

.wrc-mininav__phones {
	display: flex;
	align-items: center;
	gap: 24px;
	padding-left: 18px;
	padding-right: 14px;
	white-space: nowrap;
}
.wrc-mininav__phone { color: #fff; }
.wrc-mininav__phone-label {
	display: block;
	font-size: 11px;
	color: rgba(255, 255, 255, 0.6);
}
.wrc-mininav__phone-number {
	display: block;
	font-size: 17px;
	font-weight: 700;
	margin-top: 1px;
}
.wrc-mininav__phone-number.is-teal   { color: var(--wrc-teal-soft); }
.wrc-mininav__phone-number.is-purple { color: var(--wrc-purple-soft); }
.wrc-mininav__phone-divider {
	width: 1px;
	height: 32px;
	background: rgba(255, 255, 255, 0.12);
}

@media (max-width: 768px) {
	.wrc-mininav { bottom: 16px; }
	.wrc-mininav__menu-item { padding: 8px 10px; font-size: 12px; }
	.wrc-mininav__btn--crisis span:not(.wrc-pulse-dot) { display: none; }
	.wrc-mininav__quick-exit span { display: none; }
}


/* ---------- Quick Exit (inline / header use) ---------- */

.wrc-quick-exit {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 7px 12px;
	border-radius: var(--r-pill);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.01em;
	border: 1px solid rgba(36, 24, 48, 0.1);
	background: rgba(36, 24, 48, 0.04);
	color: var(--wrc-ink);
}
.wrc-quick-exit.is-dark {
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.18);
}


/* ---------- Announcement Bar ---------- */

.wrc-announcement {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.5s cubic-bezier(0.22, 0.8, 0.32, 1);
	background: var(--wrc-ink);
	color: #fff;
}
.wrc-announcement.is-open { max-height: 160px; }

.wrc-announcement__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	padding: 18px var(--page-gutter);
}

.wrc-announcement__lead {
	display: flex;
	align-items: center;
	gap: 16px;
	min-width: 0;
}
.wrc-announcement__dot {
	background: var(--wrc-teal-soft);
	flex-shrink: 0;
}
.wrc-announcement__eyebrow {
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.6);
	white-space: nowrap;
}
.wrc-announcement__message {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.92);
}

.wrc-announcement__phones {
	display: flex;
	align-items: center;
	gap: 28px;
	flex-shrink: 0;
}
.wrc-announcement__phone-label {
	font-size: 11px;
	color: rgba(255, 255, 255, 0.55);
	margin-right: 4px;
}
.wrc-announcement__phone-number {
	font-size: 16px;
	font-weight: 700;
}
.wrc-announcement__phone-number.is-teal   { color: var(--wrc-teal-soft); }
.wrc-announcement__phone-number.is-purple { color: var(--wrc-purple-soft); }

.wrc-announcement__close {
	width: 28px;
	height: 28px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.15);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: inherit;
	flex-shrink: 0;
}

@media (max-width: 768px) {
	.wrc-announcement__inner { flex-direction: column; align-items: flex-start; gap: 12px; padding-block: 14px; }
	.wrc-announcement.is-open { max-height: 220px; }
	.wrc-announcement__phones { flex-wrap: wrap; gap: 16px; }
}


/* ---------- Crisis Hotline Card ---------- */

.wrc-hotline-card {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	background: var(--wrc-ink);
	color: #fff;
	border-radius: 24px;
	padding: 28px 32px;
	box-shadow: 0 24px 60px -20px rgba(36, 24, 48, 0.4);
	position: relative;
	z-index: 5;
}
.wrc-hotline-card.is-overlapping { margin-top: -60px; }

.wrc-hotline-card__eyebrow {
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
}
.wrc-hotline-card__message {
	font-size: 18px;
	margin-top: 6px;
	max-width: 320px;
	line-height: 1.4;
}

.wrc-hotline-card__col {
	color: #fff;
	padding-left: 32px;
	border-left: 1px solid rgba(255, 255, 255, 0.12);
	display: block;
}
.wrc-hotline-card__col-label {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.6);
}
.wrc-hotline-card__col-number {
	font-size: 26px;
	font-weight: 700;
	margin-top: 4px;
	letter-spacing: -0.01em;
}
.wrc-hotline-card__col-number.is-teal   { color: var(--wrc-teal-soft); }
.wrc-hotline-card__col-number.is-purple { color: var(--wrc-purple-soft); }

@media (max-width: 900px) {
	.wrc-hotline-card { grid-template-columns: 1fr; gap: 18px; padding: 24px 24px; }
	.wrc-hotline-card__col { padding-left: 0; border-left: none; padding-top: 18px; border-top: 1px solid rgba(255, 255, 255, 0.12); }
	.wrc-hotline-card.is-overlapping { margin-top: -32px; }
}



/* === WRC demo overrides ===
   (remove this block to revert)
*/

/* Crisis Hotline Card: inset to match the page gutter so it does not run edge-to-edge. */
.wrc-hotline-card {
	margin-left: var(--page-gutter, 56px);
	margin-right: var(--page-gutter, 56px);
}

/* Same treatment for the Announcement Bar when it slides down. */
.wrc-announcement {
	margin: 16px var(--page-gutter, 56px) 0;
	border-radius: 20px;
}

/* Dark-bg buttons must keep white text on every interactive state. */
.wrc-btn--primary,
.wrc-btn--primary:hover,
.wrc-btn--primary:focus,
.wrc-btn--primary:active,
.wrc-btn--primary:visited,
.wrc-header__cta,
.wrc-header__cta:hover,
.wrc-header__cta:focus,
.wrc-header__cta:active,
.wrc-getinvolved__btn,
.wrc-getinvolved__btn:hover,
.wrc-getinvolved__btn:focus,
.wrc-getinvolved__btn:active {
	color: #fff;
}

/* The white-bg "Donate now" stays ink-on-white. */
.wrc-getinvolved__btn--primary,
.wrc-getinvolved__btn--primary:hover,
.wrc-getinvolved__btn--primary:focus,
.wrc-getinvolved__btn--primary:active {
	color: var(--wrc-ink);
}

/* Glass-bg secondary buttons stay ink. */
.wrc-btn--glass,
.wrc-btn--glass:hover,
.wrc-btn--glass:focus,
.wrc-btn--glass:active {
	color: var(--wrc-ink);
}
/* === end demo overrides === */
