/**
 * CandleCraft — global header, navigation, staff bar, footer.
 * Loaded from templates/layout/default.php (all pages).
 */
:root {
    --cc-ink: #3d2a22;
    --cc-ink-soft: #5c463c;
    --cc-accent: #8d5a3b;
    --cc-accent-dark: #6b3e26;
    --cc-cream: #fffaf6;
    --cc-line: #ead8cc;
    --cc-wash: linear-gradient(135deg, #f9efe7 0%, #f4d8c2 100%);
}
body { color: var(--cc-ink-soft); }
.hdr {
    background: var(--cc-wash);
    border-bottom: 1px solid var(--cc-line);
}
.hdr-inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 1rem 1.5rem 1.15rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.5rem;
}
.hdr-brand {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 10rem;
}
.hdr-brand a {
    font-weight: 800;
    font-size: 1.6rem;
    color: var(--cc-accent-dark);
    text-decoration: none;
    letter-spacing: 0.02em;
}
.hdr-tagline-logo {
    display: block;
    max-width: 300px;
    height: auto;
}
.hdr-nav-wrap {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 1.25rem 2rem;
}
.hdr-foot-wrap {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1.25rem 5rem;
}
.hdr-auth-quick {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem 0.75rem;
    flex: 0 0 auto;
}
.hdr-auth-btn {
    display: inline-block;
    padding: 0.55rem 1.35rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 1.25rem;
    text-decoration: none;
    white-space: nowrap;
}
.hdr-auth-btn--primary {
    background: var(--cc-accent);
    color: #fff;
    border: 2px solid var(--cc-accent);
}
.hdr-auth-btn--primary:hover {
    filter: brightness(1.06);
    color: #fff;
}
.hdr-auth-btn--outline {
    background: #fff;
    color: var(--cc-accent);
    border: 2px solid var(--cc-accent);
}
.hdr-auth-btn--outline:hover {
    background: #fff5ee;
}
@media (max-width: 900px) {
    .hdr-auth-quick {
        width: 100%;
        justify-content: center;
    }
}
.nav-cluster {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}
.nav-cluster-label {
    font-size: 1.15rem;
    text-transform: uppercase;
    letter-spacing: 0.09em;
    color: var(--cc-accent-dark);
    font-weight: 700;
    opacity: 0.88;
}
.nav-cluster-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 1rem;
    align-items: center;
}
.nav-cluster-links a {
    color: var(--cc-accent);
    font-weight: 700;
    font-size: 1.5rem;
    text-decoration: none;
    white-space: nowrap;
}
.nav-cluster-links a:hover { text-decoration: underline; }
.nav-cluster-links .sep {
    color: var(--cc-line);
    font-weight: 300;
    font-size: 1.12rem;
    user-select: none;
}
details.nav-more summary {
    cursor: pointer;
    font-weight: 700;
    font-size: 1.5rem;
    color: var(--cc-accent);
    list-style: none;
}
details.nav-more summary::-webkit-details-marker { display: none; }
details.nav-more[open] summary { margin-bottom: 0.35rem; }
.nav-more-panel {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.35rem 0 0 0.5rem;
    border-left: 2px solid var(--cc-line);
}
.nav-more-panel a { font-size: 1.22rem; font-weight: 600; }
.account-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid var(--cc-line);
    font-size: 0.95rem;
    color: var(--cc-ink-soft);
}
.admin-bar {
    background: #4a342c;
    color: #f5ebe3;
    border-bottom: 1px solid #3d2922;
    /* Align with main nav / body scale: one size for labels, one for actions */
    --bar-label-size: 1.15rem;
    --bar-link-size: 1.25rem;
}
.admin-bar-inner {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0.75rem 1.5rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.85rem 1.5rem;
}
.admin-bar-title {
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 800;
    color: #d4c4b8;
}
.role-badge {
    display: inline-block;
    padding: 0.25rem 0.65rem;
    border-radius: 6px;
    font-size: 1rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.role-badge--po { background: #c9a227; color: #2a1f0a; }
.role-badge--staff { background: #6b8cae; color: #fff; }
.admin-bar a {
    color: #fff;
    font-weight: 700;
    font-size: var(--bar-link-size);
    text-decoration: none;
}
.admin-bar a:hover { text-decoration: underline; }
.admin-bar-group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem 1rem;
    padding-left: 1rem;
    border-left: 1px solid rgba(255,255,255,0.2);
}
.admin-bar-group:first-of-type { border-left: none; padding-left: 0; }
.admin-bar-muted {
    color: #c9bbb0;
    font-size: var(--bar-label-size);
    font-weight: 700;
}
.main { margin-bottom: 2rem; }
.site-footer {
    margin-top: 3rem;
    padding: 2.25rem 1.5rem;
    border-top: 1px solid var(--cc-line);
    background: var(--cc-cream);
    color: var(--cc-ink-soft);
    font-size: 0.95rem;
}
.site-footer .inner { max-width: 1140px; margin: 0 auto; }
.site-footer p { margin: 0.35rem 0; }
.site-footer-heading {
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.82rem;
    color: var(--cc-accent-dark);
    margin: 1rem 0 0.5rem;
}
.site-footer-columns {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 4rem;
    margin-top: 1.25rem;
}
.site-footer-columns p { margin: 0.25rem 0; }
.site-footer-columns a { color: var(--cc-accent); font-weight: 600; text-decoration: none; }
.site-footer-columns a:hover { text-decoration: underline; }
