/* Shared SEO elements — footer, home intro */

.site-intro {
    margin: 0 0 clamp(0.75rem, 2vw, 1.25rem);
    max-width: 36ch;
    font-size: clamp(0.95rem, 0.85rem + 0.6vw, 1.15rem);
    line-height: 1.45;
    color: var(--ink);
    text-align: center;
}

.site-intro strong {
    font-weight: 700;
}

/* Visible to crawlers, hidden on screen */
.site-intro--seo {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
}

.site-nav {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.5rem, 1.5vw, 0.85rem);
}

.site-nav ul {
    width: 100%;
}

.site-band,
.site-footer {
    background-color: var(--yellow, #fad054);
    background-image: url("Flowerbackgroundhalfopacity.png");
    background-repeat: repeat;
    background-size: clamp(240px, 44vw, 1020px) auto;
}

.site-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 30;
    padding: clamp(0.15rem, 0.45vw, 0.3rem) clamp(0.75rem, 3vw, 1.25rem);
    border-top: var(--header-border, 3px solid #5d4037);
    text-align: center;
    font-size: clamp(0.65rem, 0.6rem + 0.2vw, 0.78rem);
    line-height: 1.2;
    color: var(--ink-soft, #5d4037);
}

.site-footer p {
    margin: 0;
}

body:has(.site-footer) {
    padding-bottom: 1.65rem;
}

.site-footer a {
    color: var(--ink, #3e2723);
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.site-footer a:hover {
    color: var(--ink-soft, #5d4037);
}
