/*
Theme Name: Solid Info
Theme URI: https://example.com/solid-info
Author: Solid Info
Author URI: https://example.com/
Description: Solid Info — a block (FSE) theme carrying brand tokens, self-hosted typography, and editor styles via theme.json.
Version: 0.1.0
Requires at least: 6.7
Tested up to: 6.7
Requires PHP: 8.1
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: solid-info
Tags: block-theme, full-site-editing, one-column, custom-colors, custom-menu, editor-style, featured-images
*/

/* --- T-UI-1 side padding token --- */
:root { --solid-side-padding: clamp(1rem, 3vw, 2rem); }
/* --- /T-UI-1 --- */

/* --- T-DF-font-smoothing: match live MUI rendering (otherwise text looks bolder on macOS due to default subpixel AA) --- */
body, html {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}
html { scroll-padding-top: 60px; }
/* --- /T-DF-font-smoothing --- */

main {
    min-height: calc(100vh - 343px);
}



/* --- T7 single publication --- */

/* Meta bar: just the BACK button now (date + tags moved to the byline row). */
.solid-info-single-meta {
	display: flex;
	align-items: flex-start;
	margin-bottom: 1.5rem;
}

/* Red outlined BACK button */
.solid-info-back-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.4rem 1rem;
	border: 1px solid var(--wp--preset--color--brand-pink);
	border-radius: 9999px;
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--brand-pink);
	text-decoration: none;
	transition: background-color 200ms ease, color 200ms ease;
	line-height: 1;
}
.solid-info-back-link:hover {
	background-color: var(--wp--preset--color--brand-pink);
	color: var(--wp--preset--color--white);
}
.solid-info-back-link svg {
	display: block;
	width: 14px;
	height: 14px;
}

/* Published date (top right) */
.solid-info-published-at {
	font-size: 14px;
	color: var(--wp--preset--color--slate);
	margin: 0;
}

/* Topic tags — outlined pills, right-aligned */
.solid-info-single-topics.wp-block-post-terms {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	justify-content: flex-start;
}
.solid-info-single-topics.wp-block-post-terms .wp-block-post-terms__separator {
	display: none;
}
.solid-info-single-topics.wp-block-post-terms a {
	display: inline-block;
	padding: 0.35rem 0.75rem;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 9999px;
	background: transparent;
	color: var(--wp--preset--color--slate);
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	transition: border-color 200ms ease, color 200ms ease;
	line-height: 1;
}
.solid-info-single-topics.wp-block-post-terms a:hover {
	border-color: var(--wp--preset--color--brand-pink);
	color: var(--wp--preset--color--brand-pink);
}

/* Title */
.single-publication .wp-block-post-title {
	font-family: var(--wp--preset--font-family--playfair);
	font-size: 60px;
	line-height: 1.1;
	color: var(--wp--preset--color--slate);
}


/* Byline row: brand on the left; date on the right of the brand line, topic
   tags wrap to the row beneath, also right-aligned. */
.solid-info-single-byline-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem 1rem;
	margin: 1.5rem 0 0.75rem;
}
.solid-info-single-byline-meta {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.5rem;
	margin-left: auto;
	margin-block-start: 0;
}
.solid-info-single-byline-meta .solid-info-published-at,
.solid-info-single-byline-meta .solid-info-single-topics {
	margin: 0;
}

/* Solid Info byline (brand icon + text below image) */
.solid-info-single-byline {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin: 0;
}
.solid-info-single-byline__icon {
	width: 24px;
	height: 24px;
	color: var(--wp--preset--color--slate);
	flex: 0 0 auto;
}
.solid-info-single-byline__text {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
}

/* Lead paragraph */
.solid-info-lead {
	color: var(--wp--preset--color--brand-pink);
	font-size: 18px;
	line-height: 1.5;
	font-weight: 500;
	margin-bottom: 1.5rem;
}

/* Content wrapper max width */
.single-publication .wp-block-post-content {
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
}

/* Mobile */
@media (max-width: 767px) {
	.single-publication .wp-block-post-title {
		font-size: 36px;
	}
	.solid-info-single-meta {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}
	.solid-info-single-topics.wp-block-post-terms {
		justify-content: flex-start;
	}
}
/* --- /T7 single publication --- */

/* --- T6 publication foot sections: tags, share, related --- */

/* Accessible visually-hidden helper (used by share button labels) */
.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Footer tags — wrapped row of outlined pill links (mirrors single-topics) */
.solid-info-single-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 2rem;
}
.solid-info-single-tags a {
	display: inline-block;
	padding: 0.35rem 0.75rem;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 9999px;
	background: transparent;
	color: var(--wp--preset--color--slate);
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	transition: border-color 200ms ease, color 200ms ease;
	line-height: 1;
}
.solid-info-single-tags a:hover {
	border-color: var(--wp--preset--color--brand-pink);
	color: var(--wp--preset--color--brand-pink);
}

/* Share — horizontal row of icon buttons */
.solid-info-share {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 1.5rem;
}
.solid-info-share__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 8px;
	background: transparent;
	color: var(--wp--preset--color--slate);
	cursor: pointer;
	text-decoration: none;
	transition: border-color 200ms ease, color 200ms ease;
}
.solid-info-share__btn .solid-info-share__icon {
	width: 18px;
	height: 18px;
}
.solid-info-share__btn:hover {
	border-color: var(--wp--preset--color--brand-pink);
	color: var(--wp--preset--color--brand-pink);
}
.solid-info-share__btn--save {
	width: auto;
	gap: 0.45rem;
	padding: 0 0.85rem;
	font-size: 14px;
	font-weight: 500;
}
.solid-info-share__btn--save[aria-pressed="true"] {
	border-color: var(--wp--preset--color--brand-pink);
	color: var(--wp--preset--color--brand-pink);
}
.solid-info-share__btn--save[aria-pressed="true"] .solid-info-share__icon {
	fill: currentColor;
}
.solid-info-share__btn--save:disabled {
	opacity: 0.5;
	cursor: wait;
}

/* Related publications — top-bordered section with responsive card grid */
.solid-info-related {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--wp--preset--color--panel-border);
}
.solid-info-related__title {
	font-family: var(--wp--preset--font-family--playfair);
	font-size: 32px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
	margin: 0 0 1.5rem;
}
.solid-info-related__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.5rem;
}
/* --- /T6 publication foot sections --- */

/* --- T9 sign-in pattern --- */
.solid-info-sign-in {
	max-width: 420px;
	margin: 4rem auto;
	margin-block-end: 4rem !important;
	margin-block-start: 4rem !important;
	padding: 2rem;
	background: var(--wp--preset--color--white);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.solid-info-sign-in-title {
	margin-bottom: 1.5rem;
}

.solid-info-auth-error {
	background: #fef2f2;
	border: 1px solid #fca5a5;
	border-radius: 4px;
	padding: 0.75rem 1rem;
	color: #991b1b;
	font-size: 14px;
	margin-bottom: 1rem;
}

.solid-info-auth-field {
	margin-bottom: 1rem;
}
@media (max-width: 600px) {
	.solid-info-auth-field {
		margin-bottom: 0;
		margin-top: 0.75rem;
	}
}

.solid-info-auth-field label {
	display: block;
	margin-bottom: 0.4rem;
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
}
.solid-info-auth-field--password {
	position: relative;
}
.solid-info-auth-field--password .solid-info-form-input {
	padding-right: 2.75rem;
}

.solid-info-password-toggle {
	position: absolute;
	right: 0.6rem;
	top: 60%;
	transform: translateY(-25%);
	background: none;
	border: 0;
	padding: 0.25rem;
	color: var(--wp--preset--color--slate);
	cursor: pointer;
	line-height: 1;
	opacity: 0.7;
	transition: opacity 150ms ease;
}
.solid-info-password-toggle:hover {
	opacity: 1;
}
.solid-info-password-toggle svg {
	display: block;
}

.solid-info-auth-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1.25rem;
	font-size: 14px;
}
.solid-info-auth-remember {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--wp--preset--color--slate);
	cursor: pointer;
}
.solid-info-auth-remember input {
	margin: 0;
	width: 16px;
	height: 16px;
	accent-color: var(--wp--preset--color--slate);
}
.solid-info-auth-forgot {
	color: var(--wp--preset--color--slate);
	text-decoration: none;
	font-weight: 500;
	transition: color 150ms ease;
}
.solid-info-auth-forgot:hover {
	color: var(--wp--preset--color--brand-pink);
	text-decoration: underline;
}

.solid-info-auth-submit {
	margin-bottom: 0;
}
.solid-info-auth-submit input[type="submit"] {
	background-color: var(--wp--preset--color--slate);
	color: var(--wp--preset--color--white);
	border: 0;
	border-radius: 4px;
	padding: 0.75rem 1.5rem;
	font-weight: 500;
	cursor: pointer;
	width: 100%;
	font-size: 15px;
	transition: background-color 200ms ease;
}
.solid-info-auth-submit input[type="submit"]:hover {
	background-color: #2e3a52;
}

.solid-info-auth-divider {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin: 1.25rem 0;
	font-size: 14px;
	color: var(--wp--preset--color--slate);
	opacity: 0.7;
}
.solid-info-auth-divider::before,
.solid-info-auth-divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--wp--preset--color--panel-border);
}

.solid-info-social-login {
	display: flex;
	gap: 0.75rem;
}
.solid-info-social-btn {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.6rem 0.75rem;
	border: 1px solid #435070;
	border-radius: 4px;
	background: var(--wp--preset--color--white);
	color: #435070;
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	transition: background-color 200ms ease, color 200ms ease;
	cursor: pointer;
}
.solid-info-social-btn:hover {
	background-color: #435070;
	color: var(--wp--preset--color--white);
}
.solid-info-social-btn svg {
	flex: 0 0 auto;
}

.solid-info-sign-up-link {
	text-align: center;
	margin-top: 1.5rem;
	font-size: 14px;
}
.solid-info-sign-up-link a {
	color: var(--wp--preset--color--brand-pink);
	text-decoration: none;
	font-weight: 500;
}
.solid-info-sign-up-link a:hover {
	color: var(--wp--preset--color--slate);
	text-decoration: underline;
}

.solid-info-form-input {
	display: block;
	width: 100%;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 4px;
	font-family: inherit;
	font-size: 16px;
	background: var(--wp--preset--color--white);
	box-sizing: border-box;
}
.solid-info-form-input:focus {
	outline: 2px solid var(--wp--preset--color--brand-pink);
	outline-offset: 1px;
}
/* --- /T9 sign-in pattern --- */

/* --- Sign-up pattern --- */
.solid-info-sign-up {
	max-width: 480px;
	margin: 4rem auto;
	padding: 2rem;
	margin-block-end: 4rem !important;
	margin-block-start: 4rem !important;
	background: var(--wp--preset--color--white);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}
.solid-info-sign-up-title {
	margin-bottom: 1.5rem;
}
.solid-info-auth-success {
	background: #f0fdf4;
	border: 1px solid #86efac;
	border-radius: 4px;
	padding: 0.75rem 1rem;
	color: #14532d;
	font-size: 14px;
	margin-bottom: 1rem;
}
.solid-info-sign-up-form {
	margin-bottom: 0;
}
.solid-info-sign-up-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1rem;
}
.solid-info-auth-field--file .solid-info-form-input--file {
	padding: 0.45rem 0.65rem;
	font-size: 14px;
}
.solid-info-sign-in-link {
	text-align: center;
	margin-top: 1.5rem;
	font-size: 14px;
}
.solid-info-sign-in-link a {
	color: var(--wp--preset--color--brand-pink);
	text-decoration: none;
	font-weight: 500;
}
.solid-info-sign-in-link a:hover {
	color: var(--wp--preset--color--slate);
	text-decoration: underline;
}
@media (max-width: 600px) {
	.solid-info-sign-up-grid {
		grid-template-columns: 1fr;
	}
}
/* --- /Sign-up pattern --- */

/* --- Auth header variant --- */
.solid-info-header--auth .solid-info-header-actions {
	gap: 0;
}
.solid-info-auth-prompt {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 14px;
	color: var(--wp--preset--color--slate);
}
.solid-info-auth-prompt a {
	color: var(--wp--preset--color--slate);
	font-weight: 500;
	text-decoration: none;
	transition: color 150ms ease;
}
.solid-info-auth-prompt a:hover {
	color: var(--wp--preset--color--brand-pink);
}
@media (max-width: 600px) {
	.solid-info-auth-prompt {
		font-size: 12px;
	}
}
/* --- /Auth header variant --- */

/* --- T-DF-3 header --- */
.solid-info-header {
	position: fixed !important;
	inset: 0 0 auto;
	z-index: 100;
	transition: box-shadow 200ms ease;
}
body { padding-top: 52px; }
body.is-scrolled .solid-info-header { box-shadow: 0 2px 12px rgba(0,0,0,0.06); }

.solid-info-brand {
  display: inline-flex; align-items: center;
  text-decoration: none;
  color: var(--wp--preset--color--slate);
}
.solid-info-brand-logo {
  display: block;
  height: 36px;
  width: auto;
  color: var(--wp--preset--color--slate);
}

.solid-info-nav-inline { font-family: var(--wp--preset--font-family--roboto); }
.solid-info-nav-inline .wp-block-navigation-item__content {
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wp--preset--color--slate);
  font-weight: 500;
  text-decoration: none;
}
.solid-info-nav-inline .wp-block-navigation-item__content:hover { color: var(--wp--preset--color--brand-pink); }

.solid-info-header-actions { display: inline-flex; align-items: center; gap: 0.75rem; }
.solid-info-cta-pill {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.75rem 1.2rem;
  border-radius: 9999px;
  font-family: var(--wp--preset--font-family--roboto);
  font-weight: 500; font-size: 15px; letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color 200ms, color 200ms, border-color 200ms;
  line-height: 1;
}
.solid-info-cta-pill--filled {
  background-color: var(--wp--preset--color--brand-pink);
  color: var(--wp--preset--color--white);
  border: 1px solid var(--wp--preset--color--brand-pink);
}
.solid-info-cta-pill--filled:hover { background-color: #C5193E; border-color: #C5193E; }
.solid-info-cta-pill--outline {
  background-color: transparent;
  color: var(--wp--preset--color--slate);
  border: 1px solid var(--wp--preset--color--slate);
}
.solid-info-cta-pill--outline:hover { background-color: var(--wp--preset--color--slate); color: var(--wp--preset--color--white); }
.solid-info-cta-pill svg { display: block; flex: 0 0 auto; }

/* Adaptive nav */
.solid-info-nav-toggle {
  display: none;
  background: none; border: 0; padding: 0.4rem;
  color: var(--wp--preset--color--slate); cursor: pointer;
}
.solid-info-header-left {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
@media (max-width: 1023px) {
  /* Inline nav collapses; hamburger appears on the LEFT (before brand);
     SUBSCRIBE pill + avatar stay visible on the right — matches live solid.info mobile.
     Compact everything so the header stays ~56px tall and fits the viewport. */
  .solid-info-nav-inline { display: none !important; }
  .solid-info-nav-toggle { display: inline-flex; }
  /* Override the wp:group inline padding via a more specific selector */
  header.solid-info-header.has-background {
    padding: 0.5rem var(--solid-side-padding) !important;
	  gap: 8px;
  }
  .solid-info-brand-logo { height: 26px; }
  .solid-info-nav-toggle svg { width: 22px; height: 22px; stroke-width: 2.5; }
  .solid-info-header-actions { gap: 0.4rem; }
  .solid-info-header-actions .solid-info-cta-pill {
    padding: 0.55rem 0.75rem;
    font-size: 13px;
    letter-spacing: 0.06em;
    gap: 0.3rem;
	  white-space: nowrap;
  }
  .solid-info-header-actions .solid-info-cta-pill svg { width: 12px; height: 12px; }
  .solid-info-header-avatar { width: 34px; height: 34px; }
  .solid-info-header-avatar svg { width: 16px; height: 16px; }
}


@media (max-width: 600px) {
	.solid-info-header-left {
		gap: 0;
	}
}

/* Avatar (replaces desktop SIGN IN pill) — light circle with grey border, slate icon */
.solid-info-header-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: 9999px;
  background-color: transparent;
  border: 1px solid #C9CDD4;
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  transition: background-color 200ms ease, border-color 200ms ease;
  overflow: hidden;
}
.solid-info-header-avatar:hover {
  background-color: #ECEEF1;
  border-color: var(--wp--preset--color--slate);
}
.solid-info-header-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 9999px;
  display: block;
}

/* Mobile drawer */
.solid-info-mobile-drawer {
  position: fixed; inset: 0;
  top: 3.125rem;
  background: rgba(0,0,0,0.4);
  opacity: 0; pointer-events: none;
  transition: opacity 250ms ease;
  z-index: 200;
}
.solid-info-mobile-drawer[aria-hidden="false"] { opacity: 1; pointer-events: auto; }
.solid-info-mobile-drawer__inner {
  position: absolute; inset: 0;
  width: 100%;
  background: #f0f3fa;
  padding: 1.25rem 0;
  transform: translateX(100%);
  transition: transform 250ms ease;
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  gap: 2rem;
}
.solid-info-mobile-drawer[aria-hidden="false"] .solid-info-mobile-drawer__inner { transform: translateX(0); }
.solid-info-mobile-drawer__close {
  position: absolute; top: 1rem; right: 1rem;
  background: none; border: 0; padding: 0.4rem;
  color: var(--wp--preset--color--slate); cursor: pointer;
}
.solid-info-mobile-drawer__nav {
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
  gap: 1.25rem;
}
.solid-info-mobile-drawer__nav a {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 20px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--wp--preset--color--slate); font-weight: 500;
  text-decoration: none;
  padding: 0.4rem 0;
}
/* --- /T-DF-3 header --- */

/* --- T-DF-7 single hero overlay --- */
.solid-info-single-hero {
  position: relative;
  margin: 1.5rem 0 2rem;
}
.solid-info-single-hero-image,
.solid-info-single-hero .wp-block-post-featured-image {
  margin: 0;
}
.solid-info-single-hero-image img,
.solid-info-single-hero .wp-block-post-featured-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}
.solid-info-single-hero-overlay {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  max-width: min(78%, 560px);
  background: linear-gradient(to top, rgba(67,80,112,0.92), rgba(67,80,112,0.78));
  color: var(--wp--preset--color--white);
  padding: 1rem 1.25rem;
  border-radius: 4px;
  gap: 0.5rem;
}
.solid-info-single-hero-overlay > * { margin: 0; }
.solid-info-single-hero-overlay .solid-info-published-at,
.solid-info-single-hero-overlay .solid-info-published-at--overlay {
  color: var(--wp--preset--color--white);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
}
.solid-info-single-hero-overlay .wp-block-post-title.is-in-hero-overlay,
.solid-info-single-hero-overlay .wp-block-post-title.is-in-hero-overlay a {
  color: var(--wp--preset--color--white) !important;
  font-family: var(--wp--preset--font-family--playfair);
  font-size: 32px;
  line-height: 1.15;
  font-weight: 500;
  text-decoration: none;
}
.solid-info-hero-pills {
  display: flex; flex-wrap: wrap; gap: 0.4rem;
  margin-top: 0.4rem;
}
.solid-info-hero-pills a {
  display: inline-block;
  padding: 0.15rem 0.45rem;
  background: transparent;
  color: var(--wp--preset--color--white);
  border: 1px solid rgba(255,255,255,0.85);
  border-radius: 0;
  font-size: 11px;
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 500;
}
@media (max-width: 600px) {
  .solid-info-single-hero-overlay {
    left: 0.5rem; bottom: 0.5rem; right: 0.5rem; max-width: none;
    padding: 0.75rem 1rem;
  }
  .solid-info-single-hero-overlay .wp-block-post-title.is-in-hero-overlay {
    font-size: 22px;
  }
}
/* --- /T-DF-7 single hero overlay --- */



.wp-site-blocks > * { margin-block-start: 0 !important; }

.solid-info-cookie-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.08);
}

/* --- T-UI-2 footer rebuild --- */
.solid-info-footer { font-family: var(--wp--preset--font-family--roboto); }

.solid-info-footer-row {
  display: grid;
  gap: 2rem 3rem;
  width: 100%;
  align-items: start;
}
/* Grid gap owns the spacing — null out WP's is-layout-flow margin-block on children */
.solid-info-footer-row > * { margin-top: 0; margin-bottom: 0; }
.solid-info-footer-row--top {
  grid-template-columns: 1fr 1fr 1fr;
  padding-bottom: 1.5rem;
}
@media (min-width: 720px) {
	.solid-info-footer-row--top > .solid-info-footer-brand { justify-self: center; }
}

.solid-info-footer-row--bottom {
  grid-template-columns: 1fr auto;
  align-items: center;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  margin-top: 1.5rem;
}

/* Brand column */
.solid-info-footer-brand {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 32ch;
}
.solid-info-footer-brand__link {
  display: inline-flex;
  align-items: center;
  color: var(--wp--preset--color--white);
  text-decoration: none;
}
.solid-info-footer-brand__logo {
  display: block; height: 32px; width: auto;
}
.solid-info-footer-tagline {
  font-size: 14px;
  line-height: 1.45;
  opacity: 0.85;
  margin: 0;
  font-style: italic;
}
.solid-info-footer-brand .solid-info-cta-pill {
  align-self: flex-start;
}

/* Contact column — combined socials + email card */
.solid-info-footer-contact {
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--wp--preset--color--white);
}
.solid-info-footer-contact__link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--wp--preset--color--white);
  text-decoration: none;
  font-size: 14px;
  opacity: 0.95;
  transition: opacity 200ms ease, color 200ms ease;
}
.solid-info-footer-contact__link:hover { opacity: 1; color: var(--wp--preset--color--brand-pink); }
.solid-info-footer-contact__icon { flex: 0 0 auto; color: var(--wp--preset--color--white); }
.solid-info-footer-contact__link:hover .solid-info-footer-contact__icon { color: inherit; }
.solid-info-footer-contact__link--email span { text-decoration: underline; }

/* Sections nav column */
.solid-info-footer-nav-sections {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
@media (min-width: 720px) {
	.solid-info-footer-nav-sections {
		padding-left: 2rem;
	}
}
@media (min-width: 1200px) {
	.solid-info-footer-nav-sections {
		padding-left: 5rem;
	}
}


/* Nav links (sections + legal) */
.solid-info-footer-nav-sections a,
.solid-info-footer-nav-legal a {
  color: var(--wp--preset--color--white) !important;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color 200ms ease;
}
.solid-info-footer-nav-legal a { text-decoration: underline; }
.solid-info-footer-nav-sections a:hover,
.solid-info-footer-nav-legal a:hover { color: var(--wp--preset--color--brand-pink) !important; }

/* Bottom row */
.solid-info-footer-copy {
  color: var(--wp--preset--color--white);
  opacity: 0.95;
  margin: 0;
  font-size: 13px;
  letter-spacing: 0.02em;
}
.solid-info-footer-nav-legal {
  display: flex;
  gap: 2rem;
  align-items: center;
}

/* Mobile: single column, full-width CTA, stacked bottom row */
@media (max-width: 719px) {
  .solid-info-footer-row--top {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }
  .solid-info-footer-brand .solid-info-cta-pill {
    align-self: stretch;
    justify-content: center;
  }
  .solid-info-footer-row--bottom {
    grid-template-columns: 1fr;
    gap: 1rem;
    align-items: start;
  }
  .solid-info-footer-nav-legal {
    flex-wrap: wrap;
    gap: 1.25rem;
  }
}
/* --- /T-UI-2 footer rebuild --- */

/* --- T-DF-9 patterns + cf7 --- */
/* About-team cards — visual hooks for cards built via block attributes */
.solid-info-team-card {
  border: 1px solid var(--wp--preset--color--panel-border);
  border-radius: 8px;
  box-shadow: var(--wp--custom--shadow--card);
}
.solid-info-team-role {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  opacity: 0.85;
}

/* Subscription plans — span period token */
.solid-info-plan-period {
  color: var(--wp--preset--color--slate);
  font-size: var(--wp--preset--font-size--base);
  font-weight: 400;
  margin-left: 0.25rem;
}
.solid-info-plan-card {
  background-color: var(--wp--preset--color--panel-light);
  border: 1px solid var(--wp--preset--color--panel-border);
  border-radius: 8px;
  padding: 2rem;
}
.solid-info-plan-price {
  color: var(--wp--preset--color--brand-pink);
  font-size: 32px;
  font-weight: 500;
  line-height: 1;
}
.solid-info-billing-toggle .wp-block-button.is-style-outline .wp-block-button__link {
  background-color: var(--wp--preset--color--white);
  color: var(--wp--preset--color--slate);
  border-color: var(--wp--preset--color--slate);
  border-radius: 9999px;
}
.solid-info-billing-toggle .wp-block-button:not(.is-style-outline) .wp-block-button__link {
  border-radius: 9999px;
}

/* Form input tokenization (sign-up CTA) */
.solid-info-form-input {
  border: 1px solid var(--wp--preset--color--panel-border) !important;
  border-radius: 4px;
  padding: 0.6rem 0.9rem;
  font-family: inherit;
  font-size: 16px;
  background: var(--wp--preset--color--white);
}
.solid-info-form-input:focus {
  outline: 2px solid var(--wp--preset--color--brand-pink);
  outline-offset: 1px;
}

/* Contact Form 7 brand styling */
.wpcf7-form .wpcf7-form-control:not([type="submit"]) {
  border: 1px solid var(--wp--preset--color--panel-border) !important;
  border-radius: 4px !important;
  padding: 0.65rem 0.85rem !important;
  font-family: inherit;
  font-size: 16px;
  background: var(--wp--preset--color--white);
  box-shadow: none !important;
}
.wpcf7-form .wpcf7-form-control:not([type="submit"]):focus {
  outline: 2px solid var(--wp--preset--color--brand-pink) !important;
  outline-offset: 1px;
}
.wpcf7-form .wpcf7-submit {
  background-color: var(--wp--preset--color--brand-pink) !important;
  color: var(--wp--preset--color--white) !important;
  border: 0 !important;
  border-radius: 9999px !important;
  padding: 0.65rem 1.4rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 13px;
  cursor: pointer;
  transition: background-color 200ms ease;
}
.wpcf7-form .wpcf7-submit:hover {
  background-color: #C5193E !important;
}
.wpcf7-form label {
  display: block;
  color: var(--wp--preset--color--slate);
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 0.5rem;
}
/* --- /T-DF-9 patterns + cf7 --- */

/* --- T-UI-3 section heading (all-publications) --- */
.solid-info-section-heading {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  border-top: 1px solid var(--wp--preset--color--brand-pink);
  padding-top: 0.75rem;
  margin: 0 0 1rem;
}
.solid-info-section-heading__title {
  font-family: var(--wp--preset--font-family--playfair);
  font-weight: 500;
  font-size: clamp(24px, 3vw, 32px);
  line-height: 1;
  color: var(--wp--preset--color--brand-pink);
  margin: 0;
}
.solid-info-section-heading__all {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 1rem;
  border: 1px solid var(--wp--preset--color--slate);
  color: var(--wp--preset--color--slate);
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  text-decoration: none;
  border-radius: 4px;
  background: transparent;
  transition: background-color 200ms ease, color 200ms ease;
}
.solid-info-section-heading__all::after {
  content: "\203A";
  display: inline-block;
  line-height: 1;
}
.solid-info-section-heading__all:hover {
  background: var(--wp--preset--color--slate);
  color: var(--wp--preset--color--white);
}
/* --- /T-UI-3 --- */

/* --- T-UI-4 signup CTA --- */
.solid-info-signup {
  position: relative;
  padding: 3rem;
  background-image: url('assets/images/signup-bg.webp');
  background-color: #E4E8F2;
  background-size: cover;
  background-position: center;
  border-radius: 12px;
  margin: 3rem 0;
  overflow: hidden;
}
.solid-info-signup::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(240,243,250,0.92), rgba(232,237,247,0.88));
  z-index: 0;
}
.solid-info-signup__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(200px, 1fr) minmax(380px, 1fr);
  gap: 2.5rem;
  align-items: center;
  width: 100%;
}
.solid-info-signup__pitch {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  min-width: 0;
  color: var(--wp--preset--color--slate);
}
.solid-info-signup__glyph {
  height: 112px;
  width: auto;
  flex: 0 0 auto;
  color: var(--wp--preset--color--slate);
}

.solid-info-signup__copy-block {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1 1 auto;
  min-width: 0;
}
.solid-info-signup__heading {
  font-family: var(--wp--preset--font-family--playfair);
  font-weight: 500;
  font-size: clamp(48px, 3.2vw, 64px);
  line-height: 1;
  color: var(--wp--preset--color--slate);
  margin: 0;
  white-space: nowrap;
}
.solid-info-signup__copy {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 20px;
  line-height: 1.4;
  color: var(--wp--preset--color--slate);
  margin: 0;
}
.solid-info-signup__panel {
  background: var(--wp--preset--color--slate);
  border-radius: 12px;
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  box-sizing: border-box;
  width: 100%;
}
.solid-info-signup-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.solid-info-signup-form input[type="email"] {
  width: 100%;
  max-width: 100%;
  padding: 1rem 1.25rem;
  border: 0;
  border-radius: 6px;
  background: var(--wp--preset--color--white);
  font-size: 16px;
  font-family: inherit;
  box-sizing: border-box;
  display: block;
}
.solid-info-signup-form__actions {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.solid-info-signup-form button[type="submit"] {
  flex: 0 0 auto;
  background-color: var(--wp--preset--color--brand-pink);
  color: var(--wp--preset--color--white);
  border: 0;
  border-radius: 9999px;
  padding: 0.7rem 1.6rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  cursor: pointer;
  text-transform: uppercase;
  font-family: inherit;
  font-size: 13px;
  transition: background-color 200ms ease;
}
.solid-info-signup-form button[type="submit"]:hover { background-color: #C5193E; }
.solid-info-signup-form__terms {
  flex: 1 1 auto;
  margin: 0;
  color: var(--wp--preset--color--white);
  font-size: 12px;
  line-height: 1.4;
}
.solid-info-signup-form__terms a {
  color: var(--wp--preset--color--white);
  text-decoration: underline;
}
@media  (max-width: 1023px) {
  .solid-info-signup__pitch {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    gap: 1rem;
  }
  .solid-info-signup__glyph { height: 56px; }
}
@media (max-width: 767px) {
  .solid-info-signup__inner { grid-template-columns: 1fr; }
  .solid-info-signup__pitch {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }
  .solid-info-signup-form__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .solid-info-signup-form button[type="submit"] { width: 100%; }
}
/* --- /T-UI-4 --- */

/* --- T-DF-6 archive (kept for /publications archive only) --- */
.wp-block-query-pagination {
  margin-top: 3rem;
}
.wp-block-query-pagination .page-numbers,
.wp-block-query-pagination .wp-block-query-pagination-previous,
.wp-block-query-pagination .wp-block-query-pagination-next {
  min-width: 36px;
  height: 36px;
  padding: 0 0.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--wp--preset--color--slate);
  border: 0;
  background: transparent;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: background-color 200ms ease, color 200ms ease;
}
.wp-block-query-pagination .page-numbers:hover,
.wp-block-query-pagination .wp-block-query-pagination-previous:hover,
.wp-block-query-pagination .wp-block-query-pagination-next:hover {
  color: var(--wp--preset--color--brand-pink);
}
.wp-block-query-pagination .page-numbers.current {
  background-color: var(--wp--preset--color--panel-light);
  color: var(--wp--preset--color--slate);
}
.wp-block-query-pagination .page-numbers.dots {
  color: var(--wp--preset--color--slate);
  opacity: 0.5;
}
/* --- /T-DF-6 archive --- */

/* --- Contact Form --- */
.solid-info-contact-form-wrapper {
  max-width: 720px;
  margin: 2rem auto;
}

.solid-info-contact-form__heading {
  font-family: var(--wp--preset--font-family--playfair);
  font-weight: 500;
  font-size: 48px;
  line-height: 1.1;
  color: var(--wp--preset--color--slate);
  margin: 0 0 1rem;
}

.solid-info-contact-form__description {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 16px;
  line-height: 1.6;
  color: var(--wp--preset--color--slate);
  margin: 0 0 2rem;
}

.solid-info-contact-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.solid-info-contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.solid-info-contact-form__label {
  font-family: var(--wp--preset--font-family--roboto);
  font-weight: 500;
  font-size: 14px;
  color: var(--wp--preset--color--slate);
}

.solid-info-contact-form__required {
  color: var(--wp--preset--color--brand-pink);
}

.solid-info-contact-form__input,
.solid-info-contact-form__textarea {
  border: 1px solid var(--wp--preset--color--panel-border) !important;
  border-radius: 4px !important;
  padding: 0.65rem 0.85rem !important;
  font-family: inherit;
  font-size: 16px;
  background: var(--wp--preset--color--white);
  transition: border-color 200ms ease, box-shadow 200ms ease;
}

.solid-info-contact-form__input:focus,
.solid-info-contact-form__textarea:focus {
  outline: 2px solid var(--wp--preset--color--brand-pink);
  outline-offset: 1px;
  border-color: var(--wp--preset--color--brand-pink);
}

.solid-info-contact-form__input.has-error,
.solid-info-contact-form__textarea.has-error,
.solid-info-contact-form__checkbox.has-error {
  border-color: #d32f2f !important;
}

.solid-info-contact-form__input.has-error:focus,
.solid-info-contact-form__textarea.has-error:focus {
  outline-color: #d32f2f;
}

.solid-info-contact-form__textarea {
  min-height: 140px;
  resize: vertical;
}

.solid-info-contact-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}

.solid-info-contact-form__checkbox-field {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-top: 0.25rem;
}

.solid-info-contact-form__checkbox {
  margin-top: 0.15rem;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  accent-color: var(--wp--preset--color--brand-pink);
  cursor: pointer;
}

.solid-info-contact-form__checkbox.has-error {
  outline: 2px solid #d32f2f;
  outline-offset: 1px;
}

.solid-info-contact-form__terms {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 14px;
  line-height: 1.4;
  color: var(--wp--preset--color--slate);
  cursor: pointer;
}

.solid-info-contact-form__terms a {
  color: var(--wp--preset--color--brand-pink);
  text-decoration: none;
  font-weight: 500;
}

.solid-info-contact-form__terms a:hover {
  text-decoration: underline;
}

.solid-info-contact-form__actions {
  margin-top: 0.5rem;
}

.solid-info-contact-form__submit {
  background-color: var(--wp--preset--color--brand-pink);
  color: var(--wp--preset--color--white);
  border: 0;
  border-radius: 9999px;
  padding: 0.75rem 2rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 200ms ease;
}

.solid-info-contact-form__submit:hover {
  background-color: #C5193E;
}

.solid-info-contact-form__submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.solid-info-contact-form__error {
  background-color: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 4px;
  padding: 0.75rem 1rem;
  color: #991b1b;
  font-size: 14px;
  margin-top: 0.5rem;
}

/* Contact Form Success Modal */
.solid-info-contact-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  align-items: center;
  justify-content: center;
}

.solid-info-contact-modal.is-open {
  display: flex;
}

.solid-info-contact-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

.solid-info-contact-modal__content {
  position: relative;
  background: var(--wp--preset--color--white);
  border-radius: 12px;
  padding: 2.5rem;
  max-width: 480px;
  width: calc(100% - 2rem);
  text-align: center;
  z-index: 1;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
  animation: solid-info-contact-modal-fadein 200ms ease-out;
}

@keyframes solid-info-contact-modal-fadein {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.solid-info-contact-modal__close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  background: none;
  border: 0;
  font-size: 28px;
  line-height: 1;
  color: var(--wp--preset--color--slate);
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  transition: color 200ms ease;
}

.solid-info-contact-modal__close:hover {
  color: var(--wp--preset--color--brand-pink);
}

.solid-info-contact-modal__title {
  font-family: var(--wp--preset--font-family--playfair);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  color: var(--wp--preset--color--slate);
  margin: 0 0 0.75rem;
}

.solid-info-contact-modal__subtitle {
  font-family: var(--wp--preset--font-family--roboto);
  font-weight: 500;
  font-size: 16px;
  color: var(--wp--preset--color--slate);
  margin: 0 0 0.75rem;
}

.solid-info-contact-modal__description {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 16px;
  line-height: 1.5;
  color: var(--wp--preset--color--slate);
  opacity: 0.8;
  margin: 0 0 1.5rem;
}

.solid-info-contact-modal__cta {
  display: inline-block;
  background-color: var(--wp--preset--color--brand-pink);
  color: var(--wp--preset--color--white);
  text-decoration: none;
  border-radius: 9999px;
  padding: 0.75rem 2rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background-color 200ms ease;
}

.solid-info-contact-modal__cta:hover {
  background-color: #C5193E;
  color: var(--wp--preset--color--white);
}

@media (max-width: 600px) {
  .solid-info-contact-form__heading {
    font-size: 32px;
  }
  .solid-info-contact-form__row {
    grid-template-columns: 1fr;
  }
  .solid-info-contact-modal__content {
    padding: 1.75rem;
  }
  .solid-info-contact-modal__title {
    font-size: 22px;
  }
}
/* --- /Contact Form --- */

/* --- User panel --- */
.solid-info-user-panel {
  display: flex;
  max-width: 1200px;
  margin: 2rem auto;
  min-height: calc(100vh - 200px);
  background: var(--wp--preset--color--white);
  border: 1px solid var(--wp--preset--color--panel-border);
  border-radius: 8px;
  overflow: hidden;
}

/* Sidebar */
.solid-info-user-panel__sidebar {
  width: 260px;
  flex-shrink: 0;
  background: var(--wp--preset--color--white);
  border-right: 1px solid var(--wp--preset--color--panel-border);
  display: flex;
  flex-direction: column;
  padding: 1.5rem 0;
}

.solid-info-user-panel__user {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0 1.25rem 1.25rem;
  border-bottom: 1px solid var(--wp--preset--color--panel-border);
}

.solid-info-user-panel__user-avatar {
  width: 64px;
  height: 64px;
  border-radius: 9999px;
  object-fit: cover;
  display: block;
}

.solid-info-user-panel__user-info {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.solid-info-user-panel__user-name {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 14px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.solid-info-user-panel__user-email {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 12px;
  color: var(--wp--preset--color--slate);
  opacity: 0.7;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.solid-info-user-panel__nav {
  display: flex;
  flex-direction: column;
  padding: 0.75rem 0;
  flex: 1;
}

.solid-info-user-panel__nav a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.45rem 1.25rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 13px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  transition: background-color 150ms ease, color 150ms ease;
  border-left: 3px solid transparent;
  line-height: 1;
}

.solid-info-user-panel__nav a svg {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.solid-info-user-panel__nav a:hover {
  background-color: var(--wp--preset--color--panel-light);
}

.solid-info-user-panel__nav a.is-active {
  background-color: var(--wp--preset--color--panel-light);
  border-left-color: var(--wp--preset--color--brand-pink);
  color: var(--wp--preset--color--brand-pink);
}

.solid-info-user-panel__logout {
  padding: 0.75rem 0 0;
  border-top: 1px solid var(--wp--preset--color--panel-border);
}

.solid-info-user-panel__logout a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.65rem 1.25rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 13px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  transition: color 150ms ease;
}

.solid-info-user-panel__logout a:hover {
  color: var(--wp--preset--color--brand-pink);
}

/* Mobile bottom bar */
.solid-info-user-panel__mobile-bar {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
  background: var(--wp--preset--color--white);
  border-top: 1px solid var(--wp--preset--color--panel-border);
  justify-content: space-around;
  align-items: center;
  padding: 0.4rem 0;
}

.solid-info-user-panel__mobile-bar a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  padding: 0.3rem 0.5rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 10px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  opacity: 0.7;
  transition: opacity 150ms ease, color 150ms ease;
  flex: 1;
}

.solid-info-user-panel__mobile-bar a.is-active {
  opacity: 1;
  color: var(--wp--preset--color--brand-pink);
}

.solid-info-user-panel__mobile-bar a svg {
  display: block;
}

/* Content area */
.solid-info-user-panel__content {
  flex: 1;
  padding: 2rem;
  min-width: 0;
}

.solid-info-user-panel__tab {
  display: none;
}

.solid-info-user-panel__tab.is-active {
  display: block;
}

.solid-info-user-panel__tab-title {
  font-family: var(--wp--preset--font-family--playfair);
  font-size: 28px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  margin: 0 0 1.5rem;
}

/* Profile */
.solid-info-user-panel__avatar-section {
  margin-bottom: 2rem;
}

.solid-info-user-panel__avatar-preview {
  width: 160px;
  height: 160px;
  background: var(--wp--preset--color--panel-light);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin-bottom: 0.75rem;
}

.solid-info-user-panel__avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.solid-info-user-panel__avatar-upload-btn {
  display: inline-flex;
  align-items: center;
	line-height: 0;
padding: 1rem;
  border: 1px solid var(--wp--preset--color--slate);
  border-radius: 9999px;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--wp--preset--color--slate);
  cursor: pointer;
  transition: background-color 200ms ease, color 200ms ease;
}

.solid-info-user-panel__avatar-upload-btn:hover {
  background-color: var(--wp--preset--color--slate);
  color: var(--wp--preset--color--white);
}

.solid-info-user-panel__profile-form {
  max-width: 480px;
  margin-bottom: 2rem;
}

.solid-info-user-panel__profile-form .solid-info-auth-field {
  margin-bottom: 1rem;
}

.solid-info-user-panel__profile-form label {
  display: block;
  margin-bottom: 0.4rem;
  font-size: 14px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
}

.solid-info-user-panel__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.5rem;
  border-radius: 4px;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 200ms ease, color 200ms ease;
  border: 1px solid transparent;
  text-decoration: none;
}

.solid-info-user-panel__btn--primary {
  background-color: var(--wp--preset--color--slate);
  color: var(--wp--preset--color--white);
  border-color: var(--wp--preset--color--slate);
}

.solid-info-user-panel__btn--primary:hover {
  background-color: #2e3a52;
  border-color: #2e3a52;
}

.solid-info-user-panel__btn--outline {
  background-color: transparent;
  color: var(--wp--preset--color--slate);
  border-color: var(--wp--preset--color--slate);
}

.solid-info-user-panel__btn--outline:hover {
  background-color: var(--wp--preset--color--slate);
  color: var(--wp--preset--color--white);
}

.solid-info-user-panel__password-section {
  max-width: 480px;
}

.solid-info-user-panel__password-form {
  margin-top: 1rem;
}

.solid-info-user-panel__password-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1rem;
}

.solid-info-user-panel__forgot-link {
  display: block;
  text-align: right;
  margin-top: 0.75rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 13px;
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  transition: color 150ms ease;
}

.solid-info-user-panel__forgot-link:hover {
  color: var(--wp--preset--color--brand-pink);
  text-decoration: underline;
}

.solid-info-user-panel__form-message {
  margin-top: 0.75rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 14px;
  min-height: 1.5em;
}

.solid-info-user-panel__form-message.is-success {
  color: #14532d;
}

.solid-info-user-panel__form-message.is-error {
  color: #991b1b;
}

/* Subscription + Publications */
.solid-info-user-panel__subscription p,
.solid-info-user-panel__publications-list {
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 15px;
  color: var(--wp--preset--color--slate);
  line-height: 1.5;
}

.solid-info-user-panel__publications-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.solid-info-user-panel__publications-list li {
  margin-bottom: 0.5rem;
}

.solid-info-user-panel__publications-list a {
  color: var(--wp--preset--color--slate);
  text-decoration: none;
  transition: color 150ms ease;
}

.solid-info-user-panel__publications-list a:hover {
  color: var(--wp--preset--color--brand-pink);
  text-decoration: underline;
}

/* FAQ accordion */
.solid-info-user-panel__faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.solid-info-faq-card {
  border: 1px solid var(--wp--preset--color--panel-border);
  border-radius: 8px;
  overflow: hidden;
}

.solid-info-faq-card > p:empty {
  display: none;
}

.solid-info-faq-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  width: 100%;
  padding: 1rem 1.25rem;
  background: var(--wp--preset--color--white);
  border: 0;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 15px;
  font-weight: 500;
  color: var(--wp--preset--color--slate);
  cursor: pointer;
  text-align: left;
  transition: background-color 150ms ease;
}

.solid-info-faq-card__header:hover {
  background: var(--wp--preset--color--panel-light);
}

.solid-info-faq-card__question {
  flex: 1;
}

.solid-info-faq-card__icon {
  display: block;
  width: 16px;
  height: 2px;
  background: var(--wp--preset--color--slate);
  flex-shrink: 0;
  position: relative;
  transition: background-color 150ms ease;
}

.solid-info-faq-card__icon::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 2px;
  height: 16px;
  background: var(--wp--preset--color--slate);
  transform: translate(-50%, -50%);
  transition: transform 200ms ease;
}

.solid-info-faq-card__header[aria-expanded="true"] .solid-info-faq-card__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.solid-info-faq-card__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 250ms ease;
}

.solid-info-faq-card__content.is-open {
  max-height: 500px;
}

.solid-info-faq-card__answer {
  padding: 0.75rem 1.25rem 0.5rem;
  font-family: var(--wp--preset--font-family--roboto);
  font-size: 14px;
  line-height: 1.6;
  color: var(--wp--preset--color--slate);
}

.solid-info-faq-card__answer p {
  margin: 0 0 0.75rem;
}

.solid-info-faq-card__answer p:last-child {
  margin-bottom: 0;
}

/* Mobile */
@media (max-width: 1023px) {
  .solid-info-user-panel {
    margin: 1rem;
    flex-direction: column;
  }

  .solid-info-user-panel__sidebar {
    display: none;
  }

  .solid-info-user-panel__mobile-bar {
    display: flex;
  }

  .solid-info-user-panel__content {
    padding: 1.25rem;
    padding-bottom: 5rem;
  }

  .solid-info-user-panel__tab-title {
    font-size: 24px;
  }
}

@media (max-width: 600px) {
  .solid-info-user-panel__password-actions {
    flex-direction: column;
  }

}
/* --- /User panel --- */

/* --- Forgot password pattern --- */
.solid-info-forgot-password {
	max-width: 420px;
	margin: 4rem auto;
	margin-block-end: 4rem !important;
	margin-block-start: 4rem !important;
	padding: 2rem;
	background: var(--wp--preset--color--white);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.solid-info-forgot-password-title {
	margin-bottom: 1.5rem;
}

.solid-info-forgot-password__error {
	display: none;
	background: #fef2f2;
	border: 1px solid #fca5a5;
	border-radius: 4px;
	padding: 0.75rem 1rem;
	color: #991b1b;
	font-size: 14px;
	margin-bottom: 1rem;
}

.solid-info-forgot-password__error.is-visible {
	display: block;
}

.solid-info-forgot-password__success {
	display: none;
	background: #f0fdf4;
	border: 1px solid #86efac;
	border-radius: 4px;
	padding: 0.75rem 1rem;
	color: #14532d;
	font-size: 14px;
	margin-bottom: 1rem;
}

.solid-info-forgot-password__success.is-visible {
	display: block;
}

.solid-info-forgot-password__step.is-hidden {
	display: none;
}

.solid-info-forgot-password__hint {
	text-align: center;
	font-size: 14px;
	color: var(--wp--preset--color--slate);
	margin-bottom: 1rem;
}

.solid-info-otp-row {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: 1.25rem;
}

.solid-info-otp-box {
	width: 48px;
	height: 56px;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 4px;
	text-align: center;
	font-size: 20px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
	background: var(--wp--preset--color--white);
	transition: border-color 200ms ease, box-shadow 200ms ease;
}

.solid-info-otp-box:focus {
	outline: 2px solid var(--wp--preset--color--brand-pink);
	outline-offset: 1px;
	border-color: var(--wp--preset--color--brand-pink);
}

.solid-info-forgot-password__resend {
	text-align: center;
	margin-top: 0.75rem;
	font-size: 14px;
}

.solid-info-forgot-password__resend-btn {
	background: none;
	border: 0;
	padding: 0;
	color: var(--wp--preset--color--slate);
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	transition: color 150ms ease;
}

.solid-info-forgot-password__resend-btn:hover:not(:disabled) {
	color: var(--wp--preset--color--brand-pink);
	text-decoration: underline;
}

.solid-info-forgot-password__resend-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.solid-info-forgot-password__countdown {
	font-variant-numeric: tabular-nums;
}

.solid-info-forgot-password .solid-info-auth-submit .button-primary {
	background-color: var(--wp--preset--color--slate);
	color: var(--wp--preset--color--white);
	border: 0;
	border-radius: 4px;
	padding: 0.75rem 1.5rem;
	font-weight: 500;
	cursor: pointer;
	width: 100%;
	font-size: 15px;
	transition: background-color 200ms ease;
}

.solid-info-forgot-password .solid-info-auth-submit .button-primary:hover {
	background-color: #2e3a52;
}
/* --- /Forgot password pattern --- */

/* --- Subscription tab redesign --- */
.solid-info-user-panel__subscription-label {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 15px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
	margin: 0 0 1rem;
}
.solid-info-user-panel__btn--danger {
	background-color: transparent;
	color: #d32f2f;
	border-color: #d32f2f;
}

.solid-info-user-panel__btn--danger:hover {
	background-color: #d32f2f;
	color: var(--wp--preset--color--white);
}

.solid-info-user-panel__btn--danger:focus-visible {
	outline: 2px solid #d32f2f;
	outline-offset: 2px;
}

.solid-info-subscription-card {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	padding: 2rem;
	border-radius: 8px;
	margin-bottom: 1.5rem;
}

.solid-info-subscription-card--active {
	background-color: var(--wp--preset--color--slate);
	color: var(--wp--preset--color--white);
}

.solid-info-subscription-card--alternate {
	background-color: var(--wp--preset--color--panel-light);
	border: 1px solid var(--wp--preset--color--panel-border);
	color: var(--wp--preset--color--slate);
}

.solid-info-subscription-card__main {
	flex: 1 1 235px;
	min-width: 0;
}

.solid-info-subscription-card__features {
	flex: 1 1 220px;
	min-width: 0;
}

@media (max-width: 600px) {
	.solid-info-subscription-card__features {
		flex: 1 1;
	}
}

.solid-info-subscription-card__name {
	font-family: var(--wp--preset--font-family--playfair);
	font-size: clamp(28px, 3vw, 40px);
	font-weight: 500;
	line-height: 1.1;
	margin: 0 0 0.5rem;
}

.solid-info-subscription-card--active .solid-info-subscription-card__name {
	color: var(--wp--preset--color--white);
}

.solid-info-subscription-card__tagline {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 16px;
	margin: 0 0 1.25rem;
	opacity: 0.9;
}

.solid-info-subscription-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 1rem;
}

.solid-info-subscription-card__price {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 32px;
	font-weight: 500;
	line-height: 1;
}

.solid-info-subscription-card--active .solid-info-subscription-card__price {
	color: var(--wp--preset--color--white);
}

.solid-info-subscription-card__badge {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
	background-color: var(--wp--preset--color--white);
	color: var(--wp--preset--color--slate);
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.solid-info-subscription-card__period {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 14px;
	margin: 0 0 1.25rem;
	opacity: 0.85;
	line-height: 1.4;
}

.solid-info-subscription-card__feature-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.solid-info-subscription-card__feature-list li {
	display: flex;
	align-items: end;
	gap: 0.35rem;
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 14px;
	line-height: 1.3;
}

.solid-info-subscription-card__feature-list svg {
	flex-shrink: 0;
}

.solid-info-subscription-card--active .solid-info-subscription-card__feature-list svg {
	color: var(--wp--preset--color--white);
}

.solid-info-subscription-card--alternate .solid-info-subscription-card__feature-list svg {
	color: var(--wp--preset--color--brand-pink);
}

.solid-info-subscription-card .solid-info-user-panel__btn {
	padding: 1.55rem 1.2rem;
	line-height: 0;
	width: calc(100% - 2.5rem);
}

.solid-info-subscription-card--active .solid-info-user-panel__btn--outline {
	color: var(--wp--preset--color--white);
	border-color: rgba(255, 255, 255, 0.5);
}

.solid-info-subscription-card--active .solid-info-user-panel__btn--outline:hover {
	background-color: rgba(255, 255, 255, 0.15);
	border-color: var(--wp--preset--color--white);
}

.solid-info-billing-toggle {
	display: inline-flex;
	border: 1px solid var(--wp--preset--color--slate);
	border-radius: 9999px;
	overflow: hidden;
	margin-bottom: 1rem;
}

.solid-info-billing-toggle__btn {
	padding: 0.4rem 1.1rem;
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.05em;
	background: transparent;
	border: 0;
	color: var(--wp--preset--color--slate);
	cursor: pointer;
	transition: background-color 200ms ease, color 200ms ease;
}

.solid-info-billing-toggle__btn.is-active {
	background-color: var(--wp--preset--color--slate);
	color: var(--wp--preset--color--white);
}

.solid-info-billing-toggle__btn:focus-visible {
	outline: 2px solid var(--wp--preset--color--brand-pink);
	outline-offset: 2px;
}

.solid-info-modal-overlay {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 1000;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.5);
	padding: 1rem;
}

.solid-info-modal-overlay.is-open {
	display: flex;
}

.solid-info-modal {
	background: var(--wp--preset--color--white);
	border-radius: 12px;
	padding: 2rem;
	max-width: 480px;
	width: 100%;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.solid-info-modal__title {
	font-family: var(--wp--preset--font-family--playfair);
	font-size: 24px;
	font-weight: 500;
	color: var(--wp--preset--color--slate);
	margin: 0 0 1rem;
}

.solid-info-modal__body {
	font-family: var(--wp--preset--font-family--roboto);
	font-size: 15px;
	color: var(--wp--preset--color--slate);
	line-height: 1.5;
	margin: 0 0 1.5rem;
}

.solid-info-modal__actions {
	display: flex;
	justify-content: flex-end;
	gap: 0.75rem;
	flex-wrap: wrap;
}

/* --- Manage Subscription modal --- */
.solid-info-manage-modal {
	border: 1px solid var(--wp--preset--color--slate);
}

.solid-info-manage-modal__title {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	font-size: 20px;
}

.solid-info-manage-modal__gear {
	flex-shrink: 0;
	color: var(--wp--preset--color--slate);
}

.solid-info-manage-modal__section {
	margin: 0 0 1rem;
}

.solid-info-manage-modal__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.solid-info-manage-modal__actions .solid-info-user-panel__btn {
	flex: 1 1 auto;
}

.solid-info-manage-modal__divider {
	height: 1px;
	background: var(--wp--preset--color--panel-border);
	margin: 1.25rem 0;
}

.solid-info-manage-modal__payment-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	width: 100%;
	justify-content: center;
}

.solid-info-manage-modal__external {
	flex-shrink: 0;
}

.solid-info-team-section {
	min-height: 1px;
}

.solid-info-team-section:empty {
	display: none;
}

.solid-info-team-section__title {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 0 0.5rem;
	font-size: 0.95rem;
	letter-spacing: 0.04em;
}

.solid-info-team-section__count {
	margin: 0 0 0.75rem;
	font-size: 0.85rem;
	color: var(--wp--preset--color--slate);
}

.solid-info-team-section__invite {
	display: flex;
	gap: 0.5rem;
	margin: 0 0 0.5rem;
}

.solid-info-team-section__input {
	flex: 1 1 auto;
	min-width: 0;
	padding: 0.55rem 0.75rem;
	border: 1px solid var(--wp--preset--color--panel-border);
	border-radius: 6px;
}

.solid-info-team-section__input:disabled {
	background: #f3f4f6;
	cursor: not-allowed;
}

.solid-info-team-section__full-note {
	margin: 0 0 0.75rem;
	font-size: 0.85rem;
	color: #b32d2e;
}

.solid-info-team-section__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.solid-info-team-section__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--wp--preset--color--panel-border);
}

.solid-info-team-section__item:last-child {
	border-bottom: none;
}

.solid-info-team-section__email {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.solid-info-team-section__remove {
	flex-shrink: 0;
}

@media (max-width: 600px) {
	.solid-info-subscription-card {
		flex-direction: column;
		gap: 1.5rem;
		padding: 1.5rem;
	}
}

@media (max-width: 600px) {
	.solid-info-modal {
		padding: 1.75rem;
	}
}

.solid-info-spinner {
	display: inline-block;
	width: 16px;
	height: 16px;
	border: 2px solid var(--wp--preset--color--brand-pink);
	border-top-color: transparent;
	border-radius: 50%;
	animation: solid-info-spin 0.8s linear infinite;
	margin-left: 0.5rem;
	vertical-align: middle;
}

@keyframes solid-info-spin {
	from { transform: rotate(0deg); }
	to   { transform: rotate(360deg); }
}
/* --- /Subscription tab redesign --- */

/* --- Favorite publications (bookmark toggle + favorites chip) --- */
.solid-info-fav-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 0;
	padding: 0 .375rem 0 0;
	cursor: pointer;
	color: currentColor;
	line-height: 0;
}

.solid-info-fav-toggle svg {
	display: block;
}

.solid-info-fav-toggle[aria-pressed="true"] svg {
	fill: currentColor;
	stroke: currentColor;
}

.solid-info-fav-toggle[aria-pressed="false"] svg {
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
}

.solid-info-fav-toggle:hover {
	opacity: 0.8;
}

.solid-info-fav-toggle:disabled {
	opacity: 0.5;
	cursor: wait;
}

.solid-info-tag-chip--fav {
	padding-inline: 0.5rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.solid-info-tag-chip--fav svg {
	display: block;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
}

.solid-info-tag-chip--fav.is-active svg {
	fill: currentColor;
	stroke: currentColor;
}

.solid-info-single-tags + .solid-info-fav-toggle {
	margin-inline-start: 0.5rem;
}

.solid-info-fav-toggle--in-title {
	font-size: 50px;
	margin-right: 1.5rem;
	padding: 0;
	vertical-align: baseline;
}

@media (max-width: 767px) {
	.solid-info-fav-toggle--in-title {
		font-size: 40px;
		margin-right: 0.5rem;
	}

}

.solid-info-fav-toggle--in-title svg {
	width: 1em;
	height: 1em;
}
/* --- /Favorite publications --- */

@media (max-width: 767px) {
	.wp-block-columns-mobile-reversed {
		flex-direction: column-reverse;
	}
}
