/* Reusable components — buttons, cards, callouts, fact-pairs.
   Page-specific layout in city-hub.css. */

/* ---- Site header ---- */

.site-header {
    background: var(--color-cosmos);
    color: var(--color-paper);
    border-bottom: 1px solid color-mix(in srgb, var(--color-cosmos) 50%, var(--color-paper));
}
.site-header__inner {
    max-width: var(--width-page);
    margin: 0 auto;
    padding: var(--space-2) var(--space-3);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
}
.site-header__brand {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-family: var(--font-display);
    font-size: var(--text-lg);
    color: var(--color-paper);
    text-decoration: none;
    letter-spacing: var(--tracking-wide);
}
.site-header__brand .seal {
    width: 32px;
    height: 32px;
    color: var(--color-sacred-gold);
}
.site-header__nav {
    display: flex;
    gap: var(--space-3);
    font-size: var(--text-sm);
}
.site-header__nav a {
    color: var(--color-sterling);
    text-decoration: none;
    letter-spacing: var(--tracking-wide);
}
.site-header__nav a:hover { color: var(--color-paper); }

@media (max-width: 768px) {
    .site-header__nav { display: none; }
}

/* ---- Site footer ---- */

.site-footer {
    background: var(--color-cosmos);
    color: var(--color-sterling);
    margin-top: var(--space-7);
    padding-top: var(--space-5);
    padding-bottom: var(--space-5);
    border-top: 1px solid var(--color-sacred-gold);
}
.site-footer__inner {
    max-width: var(--width-page);
    margin: 0 auto;
    padding: 0 var(--space-3);
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    justify-content: space-between;
    align-items: flex-start;
}
.site-footer__brand {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.site-footer__brand .seal { width: 48px; height: 48px; color: var(--color-sacred-gold); }
.site-footer__brand-name {
    font-family: var(--font-display);
    color: var(--color-paper);
    font-size: var(--text-xl);
    letter-spacing: var(--tracking-wide);
}
.site-footer__brand-tag {
    font-size: var(--text-sm);
    color: var(--color-sterling);
    margin-top: var(--space-1);
}
.site-footer__meta {
    font-family: var(--font-data);
    font-size: var(--text-xs);
    color: var(--color-sterling);
    text-align: right;
}
.site-footer__meta a {
    color: var(--color-sterling);
    text-decoration: underline;
}

/* ---- Callouts ---- */

.callout {
    background: var(--color-fog);
    border-left: 3px solid var(--color-info);
    padding: var(--space-2) var(--space-3);
    margin: var(--space-3) 0;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}
.callout--warning { border-left-color: var(--color-warning); }
.callout--danger  { border-left-color: var(--color-danger); }
.callout--success { border-left-color: var(--color-success); }
.callout__title {
    font-weight: 700;
    margin-bottom: var(--space-1);
}

/* ---- Fact pair (label / value) ---- */

.fact {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: var(--space-1) 0;
}
.fact__label {
    font-size: var(--text-xs);
    color: var(--color-fg-muted);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    font-weight: 500;
}
.fact__value {
    font-family: var(--font-data);
    font-size: var(--text-lg);
    color: var(--color-fg);
    font-weight: 500;
}
.fact--primary .fact__value {
    color: var(--color-sacred-gold);
    font-size: var(--text-2xl);
    font-weight: 500;
}

/* ---- Buttons / CTAs ---- */

.btn {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-weight: 500;
    text-decoration: none;
    transition: background 120ms ease, transform 80ms ease;
    cursor: pointer;
    letter-spacing: var(--tracking-wide);
    text-align: center;
}
.btn--primary {
    background: var(--color-cipher);
    color: var(--color-cosmos);
}
.btn--primary:hover {
    background: color-mix(in srgb, var(--color-cipher) 85%, var(--color-cosmos));
    color: var(--color-cosmos);
}
.btn--ghost {
    background: transparent;
    color: var(--color-cipher);
    border: 1px solid var(--color-cipher);
}
.btn--ghost:hover { background: var(--color-cipher); color: var(--color-cosmos); }
.btn:focus-visible { outline: 2px solid var(--color-sacred-gold); outline-offset: 2px; }

/* ---- Card (used by sidebar widgets) ---- */

.card {
    background: var(--color-fog);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius);
    padding: var(--space-3);
}
.card__title {
    font-family: var(--font-body);
    font-weight: 700;
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    color: var(--color-fg-muted);
    margin-bottom: var(--space-2);
}

/* ---- Sacred-gold accent rule ---- */

.gold-rule {
    width: 60px;
    height: 3px;
    background: var(--color-sacred-gold);
    border: 0;
    margin: var(--space-2) 0;
}

/* ---- Visually hidden (a11y) ---- */

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
