103 lines
2.7 KiB
Plaintext
103 lines
2.7 KiB
Plaintext
---
|
||
export interface Props {
|
||
kicker?: string;
|
||
title?: string;
|
||
intro?: string;
|
||
}
|
||
|
||
const {
|
||
kicker = "Référentiel terminologique",
|
||
title = "Glossaire archicratique",
|
||
intro = "Ce glossaire n’est pas seulement un index de définitions. Il constitue une porte d’entrée dans la pensée archicratique : une cartographie raisonnée des concepts fondamentaux, des scènes, des dynamiques et des méta-régimes à partir desquels une société peut être décrite comme organisation de tensions et recherche de co-viabilité.",
|
||
} = Astro.props;
|
||
---
|
||
|
||
<header class="glossary-hero" id="glossary-hero">
|
||
<p class="glossary-kicker">{kicker}</p>
|
||
<h1>{title}</h1>
|
||
<p class="glossary-intro">{intro}</p>
|
||
<h2
|
||
class="glossary-hero-follow"
|
||
id="glossary-hero-follow"
|
||
aria-hidden="true"
|
||
></h2>
|
||
</header>
|
||
|
||
<style>
|
||
.glossary-hero{
|
||
position: sticky;
|
||
top: var(--glossary-sticky-top);
|
||
z-index: 12;
|
||
margin-bottom: 28px;
|
||
padding: 14px 16px 18px;
|
||
border: 1px solid rgba(127,127,127,0.18);
|
||
border-radius: 28px;
|
||
background:
|
||
linear-gradient(180deg, rgba(0,0,0,0.60), rgba(0,0,0,0.90)),
|
||
radial-gradient(900px 240px at 20% 0%, rgba(0,217,255,0.08), transparent 60%);
|
||
transition:
|
||
background 300ms cubic-bezier(.22,.8,.22,1),
|
||
border-color 300ms cubic-bezier(.22,.8,.22,1),
|
||
box-shadow 300ms cubic-bezier(.22,.8,.22,1);
|
||
backdrop-filter: blur(10px);
|
||
-webkit-backdrop-filter: blur(10px);
|
||
display: grid;
|
||
row-gap: 12px;
|
||
}
|
||
|
||
.glossary-kicker{
|
||
margin: 0;
|
||
font-size: 12px;
|
||
letter-spacing: .12em;
|
||
text-transform: uppercase;
|
||
opacity: .72;
|
||
}
|
||
|
||
.glossary-hero h1{
|
||
margin: 0;
|
||
font-size: clamp(2.2rem, 4vw, 3.15rem);
|
||
line-height: 1.02;
|
||
letter-spacing: -.04em;
|
||
font-weight: 850;
|
||
}
|
||
|
||
.glossary-intro{
|
||
margin: 0;
|
||
max-width: 72ch;
|
||
font-size: 1.05rem;
|
||
line-height: 1.55;
|
||
opacity: .94;
|
||
}
|
||
|
||
.glossary-hero-follow{
|
||
margin: 2px 0 0;
|
||
min-height: var(--glossary-follow-height);
|
||
display: flex;
|
||
align-items: flex-end;
|
||
opacity: 0;
|
||
transform: translateY(10px) scale(.985);
|
||
filter: blur(6px);
|
||
transition:
|
||
opacity 220ms cubic-bezier(.22,1,.36,1),
|
||
transform 320ms cubic-bezier(.22,1,.36,1),
|
||
filter 320ms cubic-bezier(.22,1,.36,1);
|
||
pointer-events: none;
|
||
white-space: nowrap;
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
will-change: opacity, transform, filter;
|
||
}
|
||
|
||
.glossary-hero-follow.is-visible{
|
||
opacity: 1;
|
||
transform: translateY(0) scale(1);
|
||
filter: blur(0);
|
||
}
|
||
|
||
@media (max-width: 760px){
|
||
.glossary-hero{
|
||
top: calc(var(--glossary-sticky-top) - 2px);
|
||
padding: 12px 14px 16px;
|
||
}
|
||
}
|
||
</style> |