@layer bricks {:where(.brxe-svg){height:auto;width:auto}:where(.brxe-svg) svg{height:auto;max-width:100%;overflow:visible;width:auto}}@layer bricks {@keyframes load8{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes scrolling{0%{opacity:1}to{opacity:0;-webkit-transform:translateY(10px);transform:translateY(10px)}}a.brxe-image{display:inline-block}figure.brxe-image{margin:0}:where(.brxe-image).tag{display:inline-block;height:fit-content;position:relative;width:auto}:where(.brxe-image).caption{position:relative}:where(.brxe-image).caption:has(figcaption.bricks-image-caption){overflow:hidden}:where(.brxe-image).overlay{position:relative}:where(.brxe-image).overlay:before{bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}:where(.brxe-image):before{border-radius:inherit}:where(.brxe-image) a{border-radius:inherit;position:static;transition:inherit}:where(.brxe-image) picture{border-radius:inherit;transition:inherit}:where(.brxe-image) img{border-radius:inherit;height:100%;position:static!important;transition:inherit;width:100%}:where(.brxe-image) img.bricks-lazy-hidden+figcaption{display:none}:where(.brxe-image) .icon{color:#fff;font-size:60px;pointer-events:none;position:absolute;right:50%;text-align:center;top:50%;transform:translate(50%,-50%);z-index:5}:where(.brxe-image) .bricks-image-caption{background:linear-gradient(0deg,rgba(0,0,0,.5),rgba(0,0,0,.25) 70%,transparent);bottom:0;color:#fff;font-size:inherit;margin:0;padding:10px 15px;pointer-events:none;position:absolute;text-align:center;width:100%;z-index:1}}@layer bricks {:where(.brxe-heading).has-separator{align-items:center;display:inline-flex;gap:20px}:where(.brxe-heading)>[contenteditable]{display:inline-block;text-decoration:inherit}:where(.brxe-heading) .separator{border-top:1px solid;flex-grow:1;flex-shrink:0;height:1px}}@layer bricks {.brxe-text-link{gap:5px}.brxe-text-link,.brxe-text-link span{align-items:center;display:inline-flex}.brxe-text-link span{justify-content:center}.brxe-text-link .icon{flex-shrink:0}} .btn { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; letter-spacing: 0.025em; padding: var(--space-3) var(--space-6); border: 2px solid transparent; cursor: pointer; transition: background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition); text-decoration: none; white-space: nowrap; } .btn--primary { background: var(--color-primary); color: hsl(0, 0%, 100%); border-color: var(--color-primary); } .btn--primary:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); } .btn--primary:active { background: var(--color-primary-active); } .btn--outline { background: transparent; color: var(--color-primary); border-color: var(--color-primary); } .btn--outline:hover { background: var(--color-primary); color: hsl(0, 0%, 100%); } .btn--outline-white { background: transparent; color: hsl(0, 0%, 100%); border-color: hsl(0, 0%, 100%); } .btn--outline-white:hover { background: hsl(0, 0%, 100%); color: var(--color-primary); } .btn--donate { background: var(--color-accent); color: hsl(0, 0%, 100%); border-color: var(--color-accent); font-size: var(--text-xs); padding: var(--space-2) var(--space-4); letter-spacing: 0.08em; text-transform: uppercase; } .btn--donate:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); } .btn--sm { padding: var(--space-2) var(--space-4); font-size: var(--text-xs); } .btn--download { background: var(--color-primary); color: hsl(0, 0%, 100%); border-color: var(--color-primary); gap: var(--space-2); } .btn--download:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); } .btn--download svg { flex-shrink: 0; } .page-hero { background: var(--color-primary); position: relative; overflow: hidden; padding-block: clamp(var(--space-12), 7vw, var(--space-24)); } .page-hero::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient( 0deg, hsl(231 51% 100% / 0.04) 0px, hsl(231 51% 100% / 0.04) 1px, transparent 1px, transparent 48px ), repeating-linear-gradient( 90deg, hsl(231 51% 100% / 0.04) 0px, hsl(231 51% 100% / 0.04) 1px, transparent 1px, transparent 48px ); pointer-events: none; } .page-hero__inner { position: relative; display: grid; grid-template-columns: 1fr auto; align-items: end; gap: var(--space-8); } .page-hero__breadcrumb { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: hsl(214, 23%, 74%); margin-bottom: var(--space-5); } .page-hero__breadcrumb a { color: inherit; } .page-hero__breadcrumb a:hover { color: hsl(0, 0%, 100%); } .page-hero__breadcrumb-sep { color: hsl(214, 23%, 55%); font-size: var(--text-xs); } .page-hero__eyebrow { display: inline-block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand-red); background: hsl(4 55% 59% / 0.14); padding: var(--space-1) var(--space-3); margin-bottom: var(--space-4); } .page-hero__title { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; color: hsl(0, 0%, 100%); line-height: 1.1; margin-bottom: var(--space-4); } .page-hero__title em { font-style: italic; color: hsl(214, 23%, 80%); } .page-hero__desc { font-size: var(--text-base); color: hsl(214, 23%, 78%); max-width: 58ch; line-height: 1.7; } .page-hero__stats { display: flex; flex-direction: column; gap: var(--space-5); text-align: right; flex-shrink: 0; } .page-hero__stat-value { display: block; font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: hsl(0, 0%, 100%); line-height: 1; } .page-hero__stat-label { display: block; font-size: var(--text-xs); color: hsl(214, 23%, 68%); letter-spacing: 0.06em; text-transform: uppercase; margin-top: var(--space-1); } @media (max-width: 640px) { .page-hero__inner { grid-template-columns: 1fr; } .page-hero__stats { flex-direction: row; text-align: left; flex-wrap: wrap; gap: var(--space-6); } }  .pub-section-intro { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-6); margin-bottom: var(--space-10); padding-bottom: var(--space-6); border-bottom: 2px solid var(--color-primary); } .pub-section-intro__text .pub-section-intro__desc { font-size: var(--text-base); color: var(--color-text-muted); max-width: 60ch; margin-top: var(--space-3); } .pub-section-intro__count { flex-shrink: 0; font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--color-text-faint); letter-spacing: -0.02em; white-space: nowrap; } @media (max-width: 640px) { .pub-section-intro { flex-direction: column; align-items: flex-start; } }  .pub-card { display: grid; grid-template-columns: 1fr auto; gap: 0; background: var(--color-surface); border: 1px solid hsl(231 30% 15% / 0.10); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition), transform var(--transition); position: relative; overflow: hidden; } .pub-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }  .pub-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--color-accent); } .pub-card__body { padding: var(--space-8) var(--space-8) var(--space-8) var(--space-8); display: flex; flex-direction: column; gap: var(--space-5); } .pub-card__meta-row { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; } .pub-card__series-badge { display: inline-block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; background: var(--color-primary); color: hsl(0, 0%, 100%); padding: var(--space-1) var(--space-3); } .pub-card__type-badge { display: inline-block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; background: hsl(231 20% 93%); color: var(--color-text-muted); padding: var(--space-1) var(--space-3); } [data-theme="dark"] .pub-card__type-badge { background: var(--color-surface-offset); color: var(--color-text-muted); } .pub-card__year { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-faint); letter-spacing: 0.06em; } .pub-card__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--color-text); line-height: 1.25; } .pub-card__title a { transition: color var(--transition); } .pub-card__title a:hover { color: var(--color-primary); } .pub-card__author-row { display: flex; align-items: center; gap: var(--space-3); } .pub-card__author-avatar { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; flex-shrink: 0; background: var(--color-surface-2); border: 2px solid var(--color-border); } .pub-card__author-avatar img { width: 100%; height: 100%; object-fit: cover; } .pub-card__author-name { font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; color: var(--color-text); } .pub-card__author-affil { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: 1px; } .pub-card__abstract { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; max-width: 70ch; } .pub-card__footer { display: flex; align-items: center; gap: var(--space-4); padding-top: var(--space-2); flex-wrap: wrap; } .pub-card__pages { font-size: var(--text-xs); color: var(--color-text-faint); display: flex; align-items: center; gap: var(--space-2); } .pub-card__pages svg { color: var(--color-text-faint); } .pub-card__lang { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-faint); border: 1px solid var(--color-border); padding: 2px 8px; } .pub-card__pdf-panel { width: 140px; flex-shrink: 0; background: hsl(231 20% 93%); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3); padding: var(--space-6) var(--space-4); border-left: 1px solid hsl(231 30% 15% / 0.08); align-self: stretch;  min-height: 100%; } [data-theme="dark"] .pub-card__pdf-panel { background: var(--color-surface-offset); } .pub-card__pdf-thumb { width: 80px; height: 104px; object-fit: cover; box-shadow: 2px 3px 8px hsl(231 30% 10% / 0.18), 0 1px 2px hsl(231 30% 10% / 0.10); border: 1px solid hsl(231 30% 15% / 0.12); } .pub-card__pdf-label { font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-text-faint); } @media (max-width: 700px) { .pub-card { grid-template-columns: 1fr; } .pub-card__pdf-panel { display: none; } }  .forthcoming-note { margin-top: var(--space-8); border: 1.5px dashed hsl(231 30% 15% / 0.20); padding: var(--space-8) var(--space-8); display: flex; align-items: flex-start; gap: var(--space-5); background: hsl(231 20% 97%); } [data-theme="dark"] .forthcoming-note { border-color: hsl(231 30% 70% / 0.15); background: hsl(231 22% 11%); } .forthcoming-note__icon { flex-shrink: 0; width: 40px; height: 40px; color: var(--color-text-faint); margin-top: 2px; } .forthcoming-note__title { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; color: var(--color-text-muted); margin-bottom: var(--space-2); } .forthcoming-note__body { font-size: var(--text-sm); color: var(--color-text-faint); line-height: 1.7; max-width: 65ch; } .forthcoming-note__cta { margin-top: var(--space-4); font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.06em; color: var(--color-primary); text-decoration: none; display: inline-flex; align-items: center; gap: var(--space-2); border-bottom: 1px solid currentColor; padding-bottom: 1px; transition: color var(--transition), opacity var(--transition); } .forthcoming-note__cta:hover { color: var(--color-primary-hover); }  .books-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr)); gap: var(--space-8); } .book-card { background: var(--color-surface); border: 1px solid hsl(231 30% 15% / 0.10); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition), transform var(--transition); display: flex; flex-direction: column; position: relative; } .book-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); } .book-card__cover-wrap { position: relative; overflow: hidden; background: var(--color-surface-2); aspect-ratio: 3 / 4; } .book-card__cover { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); } .book-card:hover .book-card__cover { transform: scale(1.04); } .book-card__publisher-badge { position: absolute; top: var(--space-3); left: var(--space-3); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; background: hsl(0 0% 0% / 0.68); color: hsl(0, 0%, 100%); padding: var(--space-1) var(--space-3); } .book-card__body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; } .book-card__expert-row { display: flex; align-items: center; gap: var(--space-2); } .book-card__expert-dot { width: 8px; height: 8px; background: var(--color-accent); flex-shrink: 0; } .book-card__expert-label { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-accent); } .book-card__title { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; color: var(--color-text); line-height: 1.3; } .book-card__author { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); } .book-card__affil { font-size: var(--text-xs); color: var(--color-text-faint); } .book-card__desc { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; flex: 1; } .book-card__footer { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding-top: var(--space-4); border-top: 1px solid var(--color-divider); margin-top: auto; flex-wrap: wrap; } .book-card__year-isbn { font-size: var(--text-xs); color: var(--color-text-faint); line-height: 1.5; } .book-card__order-link { font-size: var(--text-xs); font-weight: 600; color: var(--color-primary); display: inline-flex; align-items: center; gap: var(--space-1); border-bottom: 1px solid currentColor; padding-bottom: 1px; transition: color var(--transition); } .book-card__order-link:hover { color: var(--color-primary-hover); }  .books-forthcoming { margin-top: var(--space-8); border: 1.5px dashed hsl(231 30% 15% / 0.18); padding: var(--space-6) var(--space-8); display: flex; align-items: center; gap: var(--space-6); background: hsl(231 20% 97%); flex-wrap: wrap; } [data-theme="dark"] .books-forthcoming { border-color: hsl(231 30% 70% / 0.15); background: hsl(231 22% 11%); } .books-forthcoming__text { font-size: var(--text-sm); color: var(--color-text-faint); line-height: 1.65; max-width: 55ch; } .books-forthcoming__text strong { display: block; font-family: var(--font-display); font-size: var(--text-base); color: var(--color-text-muted); margin-bottom: var(--space-2); }  .submission-strip { background: var(--color-surface-offset); border-top: 3px solid var(--color-primary); border-bottom: 1px solid var(--color-border); padding-block: var(--space-8); } .submission-strip__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); flex-wrap: wrap; } .submission-strip__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--color-text); margin-bottom: var(--space-2); } .submission-strip__body { font-size: var(--text-sm); color: var(--color-text-muted); max-width: 55ch; line-height: 1.65; }  .publications-page { padding-bottom: var(--space-24); } .pub-section { padding-block: clamp(var(--space-12), 7vw, var(--space-20)); } .pub-section + .pub-section { border-top: 1px solid var(--color-divider); } .pub-section--alt { background: var(--color-surface-2); }  .reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.55s cubic-bezier(0.16,1,0.3,1), transform 0.55s cubic-bezier(0.16,1,0.3,1); } .reveal.is-visible { opacity: 1; transform: translateY(0); } .reveal--delay-1 { transition-delay: 0.08s; } .reveal--delay-2 { transition-delay: 0.16s; } .reveal--delay-3 { transition-delay: 0.24s; } #brxe-pfbskw {width: 36px; height: 36px} #brxe-drymke {width: 80px; height: 104px} #brxe-fzclwv {flex-shrink: 0} #brxe-hxlzgg {width: 400px; height: 533px} #brxe-xaqjuk {width: 400px; height: 533px} #brxe-fvvdrc {width: 400px; height: 533px} 