/* ================================================================
 * Bondgenoot — components/parchment-card.css
 * /assets/css/components/parchment-card.css
 * Cluster D — Pakket D3 — FIX-015
 *
 * Centrale perkament-kaart-styling voor ALLE outgame-pagina's die
 * een "boek/document"-presentatie willen: /privacy, /faq, /regels,
 * /nieuws, /changelog, /over-ons, /contact, /beheer/cms, …
 *
 * VÓÓR FIX-015 stond deze stijl in pages/privacy.css en werd alleen
 * geladen op page-privacy / page-content. Andere pagina's gebruikten
 * óók .pp-shell / .pp-content maar zónder de perkament-bg → donkere
 * inkt op donker bruin = onleesbaar (zie checker FIX-015 A1-A4).
 *
 * Deze file wordt nu GLOBAAL ingeladen door outgame.tpl.php zodat
 * elke pagina die de mark-up `<div class="pp-shell"><article class=
 * "pp-content">…</article></div>` gebruikt automatisch een perkament-
 * kaart krijgt.
 *
 * Filosofie: GEEN page-specifieke overrides hier. Pagina-specifieke
 * extra's (FAQ-zoekbalk, news-meta, …) staan in pages/{naam}.css.
 *
 * Tokens: alle kleuren via var(--…-…) uit tokens.css.
 * ================================================================ */

/* ---------- Shell + container ---------- */

.pp-shell {
    width: 100%;
    max-width: 880px;
    margin: 0 auto;
    padding: 0;
}

/* Variant met breder canvas voor admin/cms-list (tabellen e.d.) */
.pp-shell--wide {
    max-width: 1200px;
}

/* ---------- Perkament-kaart zelf ---------- */

.pp-content {
    position: relative;
    color: var(--text-on-parchment, #2A1F0E);
    border: 1px solid var(--gold, var(--gold));
    border-radius: var(--radius-md, var(--radius-md));
    padding: var(--space-7) 60px 56px;
    overflow: hidden;
    font-family: var(--font-content, 'Lora', Georgia, serif);
    font-size: 1.04rem;
    line-height: 1.78;

    /* Parchment textuur via stacked gradients — zelfde recept als V1 */
    background-color: var(--bg-parchment-1, var(--bg-parchment-1));
    background-image:
        radial-gradient(circle at 23% 47%, rgba(140, 103, 34, 0.06) 0%, transparent 14%),
        radial-gradient(circle at 76% 71%, rgba(140, 103, 34, 0.08) 0%, transparent 18%),
        radial-gradient(circle at 41% 18%, rgba(0, 0, 0, 0.025) 0%, transparent 11%),
        radial-gradient(circle at 88% 32%, rgba(140, 103, 34, 0.05) 0%, transparent 13%),
        radial-gradient(circle at 12% 88%, rgba(0, 0, 0, 0.020) 0%, transparent 9%),
        radial-gradient(circle at 58% 55%, rgba(140, 103, 34, 0.04) 0%, transparent 16%),
        repeating-linear-gradient(35deg,
            rgba(184, 137, 61, 0.030) 0px, rgba(184, 137, 61, 0.030) 1px,
            transparent 1px, transparent 4px),
        repeating-linear-gradient(-35deg,
            rgba(184, 137, 61, 0.022) 0px, rgba(184, 137, 61, 0.022) 1px,
            transparent 1px, transparent 5px),
        radial-gradient(ellipse 100% 100% at 50% 50%,
            transparent 60%, rgba(140, 103, 34, 0.10) 100%),
        linear-gradient(180deg, var(--bg-parchment-1, var(--bg-parchment-1)) 0%, var(--bg-parchment-2, var(--bg-parchment-2)) 100%);

    box-shadow:
        0 14px 40px rgba(0, 0, 0, 0.55),
        0 4px 10px rgba(0, 0, 0, 0.35),
        inset 0 1px 0 rgba(255, 255, 255, 0.75),
        inset 0 -3px 6px rgba(140, 103, 34, 0.18),
        inset 2px 0 4px rgba(140, 103, 34, 0.06),
        inset -2px 0 4px rgba(140, 103, 34, 0.06);
}

/* Goud-band aan de bovenkant (inlay-effect) */
.pp-content::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background:
        linear-gradient(180deg,
            transparent 0%, transparent 33%,
            rgba(255, 245, 200, 0.80) 33%,
            rgba(255, 245, 200, 0.80) 66%,
            transparent 66%, transparent 100%
        ),
        linear-gradient(90deg,
            transparent 0%,
            var(--gold-deep, var(--gold-deep)) 14%,
            var(--gold, var(--gold)) 35%,
            var(--gold-bright, var(--gold-bright)) 50%,
            var(--gold, var(--gold)) 65%,
            var(--gold-deep, var(--gold-deep)) 86%,
            transparent 100%
        );
    z-index: 2;
}

/* Hoek-ornament rechtsboven */
.pp-content::after {
    content: "❦";
    position: absolute;
    top: 12px; right: 18px;
    color: rgba(140, 103, 34, 0.25);
    font-size: 18px;
    line-height: 1;
    pointer-events: none;
}

@media (max-width: 600px) {
    .pp-content { padding: var(--space-6) var(--space-5) 40px; font-size: 0.98rem; }
}

/* ---------- Heading-systeem op perkament ---------- */

.pp-content h1,
.pp-content h2,
.pp-content h3,
.pp-content h4,
.pp-content h5,
.pp-content h6 {
    font-family: var(--font-display, 'Cinzel', serif);
    color: var(--gold-deep, var(--gold-deep));
    margin-top: var(--space-5, var(--space-5));
    margin-bottom: var(--space-3, var(--space-3));
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.55);
    letter-spacing: 0.03em;
    line-height: 1.25;
    position: relative;
    z-index: 2;
}

.pp-content h1 {
    margin-top: 0;
    font-size: 2.2rem;
    border-bottom: 2px solid rgba(184, 137, 61, 0.40);
    padding-bottom: var(--space-3, var(--space-3));
    text-transform: uppercase;
    text-align: center;
}

.pp-content h1::after {
    content: "❦";
    display: block;
    color: rgba(140, 103, 34, 0.45);
    font-size: 16px;
    margin-top: var(--space-2);
    border: 0;
}

.pp-content h2 { font-size: 1.55rem; }
.pp-content h3 { font-size: 1.22rem; color: var(--text-on-parchment, #2A1F0E); }
.pp-content h4 { font-size: 1.10rem; color: var(--text-on-parchment, #2A1F0E); }

/* ---------- Body-typografie ---------- */

.pp-content p,
.pp-content li {
    color: var(--text-on-parchment, #2A1F0E);
    position: relative;
    z-index: 2;
}

.pp-content ul,
.pp-content ol {
    margin: 0 0 var(--space-4, var(--space-4));
    padding-left: var(--space-6, var(--space-6));
    position: relative;
    z-index: 2;
}

.pp-content ul li::marker { color: var(--gold, var(--gold)); }

.pp-content a {
    color: var(--gold-deep, var(--gold-deep));
    text-decoration: underline;
    text-decoration-color: rgba(184, 137, 61, 0.55);
    text-underline-offset: 3px;
    font-weight: 600;
}

.pp-content a:hover {
    color: var(--accent-ink, var(--accent-ink));
    text-decoration-color: var(--gold, var(--gold));
    text-shadow: none;
}

.pp-content blockquote {
    margin: var(--space-4, var(--space-4)) 0;
    padding: var(--space-3, var(--space-3)) var(--space-5, var(--space-5));
    border-left: 4px solid var(--gold, var(--gold));
    background: rgba(184, 137, 61, 0.10);
    color: var(--text-on-parchment-muted, #6B5237);
    font-style: italic;
    position: relative;
    z-index: 2;
}

.pp-content code {
    background: rgba(0, 0, 0, 0.06);
    color: var(--accent-ink, var(--accent-ink));
    padding: 0.1em 0.4em;
    border-radius: var(--radius-sm, var(--radius-sm));
    font-size: 0.92em;
}

.pp-content table {
    width: 100%;
    border-collapse: collapse;
    margin: var(--space-4, var(--space-4)) 0;
    font-family: var(--font-body, 'Manrope', sans-serif);
    font-size: 0.95rem;
    position: relative;
    z-index: 2;
}

.pp-content th,
.pp-content td {
    text-align: left;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(184, 137, 61, 0.32);
}

.pp-content th {
    color: var(--gold-deep, var(--gold-deep));
    font-weight: 700;
    background: rgba(184, 137, 61, 0.10);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.82rem;
}

.pp-content hr {
    border: 0;
    margin: var(--space-5, var(--space-5)) 0;
    height: 16px;
    background-image:
        linear-gradient(90deg,
            transparent 0%, rgba(184, 137, 61, 0.5) 50%, transparent 100%);
    background-size: 100% 1px;
    background-repeat: no-repeat;
    background-position: center;
    position: relative;
    text-align: center;
}

.pp-content hr::before {
    content: "❦";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--bg-parchment-1, var(--bg-parchment-1));
    color: var(--gold, var(--gold));
    padding: 0 var(--space-3);
    font-size: 12px;
}

/* ---------- Meta-band bovenin ---------- */

.pp-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3, var(--space-3));
    margin: -var(--space-2) 0 var(--space-4, var(--space-4));
    padding: var(--space-2) 0;
    border-bottom: 1px dashed rgba(184, 137, 61, 0.45);
    font-family: var(--font-body, 'Manrope', sans-serif);
    font-size: 0.85rem;
    color: var(--text-on-parchment-muted, #6B5237);
    position: relative;
    z-index: 2;
}

.pp-meta-label {
    background: linear-gradient(180deg,
        var(--gold-deep, var(--gold-deep)) 0%,
        #6B4F1A 100%);
    color: var(--bg-parchment-1, var(--bg-parchment-1));
    padding: var(--space-1) var(--space-3);
    border-radius: 12px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.20),
        0 1px 2px rgba(0, 0, 0, 0.30);
}

.pp-meta-badge {
    color: var(--accent-bordeaux, var(--accent-bordeaux));
    border: 1px solid var(--accent-bordeaux, var(--accent-bordeaux));
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* ---------- Summary callout (privacy "wat is gewijzigd"-blok, etc.) ---------- */

.pp-summary {
    margin: 0 0 var(--space-5, var(--space-5));
    padding: var(--space-3, var(--space-3)) var(--space-4, var(--space-4));
    background:
        linear-gradient(180deg,
            rgba(184, 137, 61, 0.12) 0%,
            rgba(184, 137, 61, 0.06) 100%
        );
    border-left: 4px solid var(--gold, var(--gold));
    border-radius: 0 var(--radius-sm, var(--radius-sm)) var(--radius-sm, var(--radius-sm)) 0;
    position: relative;
    z-index: 2;
}

.pp-summary strong {
    display: block;
    color: var(--gold-deep, var(--gold-deep));
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.8rem;
    margin-bottom: var(--space-2, var(--space-2));
}

/* ---------- Voet / back-link ---------- */

.pp-footer {
    margin-top: var(--space-5, var(--space-5));
    padding-top: var(--space-3, var(--space-3));
    border-top: 1px dashed rgba(184, 137, 61, 0.45);
    position: relative;
    z-index: 2;
}

.pp-back-link {
    color: var(--gold-deep, var(--gold-deep));
    font-weight: 700;
    text-decoration: underline;
    text-decoration-color: rgba(184, 137, 61, 0.55);
    text-underline-offset: 3px;
}
.pp-back-link:hover {
    color: var(--accent-ink, var(--accent-ink));
    text-decoration-color: var(--gold, var(--gold));
    text-shadow: none;
}

/* ---------- Form-elements binnen perkament ---------- */
/* (FIX-015 — voor /contact, /faq-search, ed.) */

.pp-content input[type="text"],
.pp-content input[type="email"],
.pp-content input[type="search"],
.pp-content input[type="tel"],
.pp-content input[type="url"],
.pp-content textarea,
.pp-content select {
    width: 100%;
    box-sizing: border-box;
    padding: 10px 14px;
    background:
        linear-gradient(180deg,
            rgba(255, 251, 238, 0.95) 0%,
            rgba(252, 244, 222, 0.95) 100%);
    color: var(--text-on-parchment, #2A1F0E);
    border: 1px solid rgba(140, 103, 34, 0.45);
    border-radius: var(--radius-sm, var(--radius-sm));
    font-family: inherit;
    font-size: 0.95rem;
    line-height: 1.5;
    box-shadow: inset 0 1px 3px rgba(140, 103, 34, 0.10);
    transition: border-color var(--t-fast) ease, box-shadow var(--t-fast) ease;
}

.pp-content input:focus,
.pp-content textarea:focus,
.pp-content select:focus {
    outline: none;
    border-color: var(--gold, var(--gold));
    box-shadow:
        inset 0 1px 3px rgba(140, 103, 34, 0.10),
        0 0 0 3px rgba(184, 137, 61, 0.20);
}

.pp-content textarea {
    resize: vertical;
    min-height: 120px;
    font-family: var(--font-body, 'Manrope', sans-serif);
}

.pp-content label {
    display: block;
    margin: 0 0 6px;
    font-weight: 600;
    color: var(--gold-deep, var(--gold-deep));
    font-size: 0.92rem;
}

/* Forms zonder pp-content directly: ook fields stylen */
.pp-form-row {
    margin-bottom: var(--space-4, var(--space-4));
    position: relative;
    z-index: 2;
}

.pp-form-help {
    display: block;
    margin-top: var(--space-1);
    font-size: 0.85rem;
    color: var(--text-on-parchment-muted, #6B5237);
    font-style: italic;
}

.pp-form-error {
    display: block;
    margin-top: var(--space-1);
    font-size: 0.88rem;
    color: var(--accent-bordeaux, var(--accent-bordeaux));
    font-weight: 600;
}

/* ---------- Knoppen op perkament ---------- */

.pp-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 10px 22px;
    border-radius: var(--radius-sm, var(--radius-sm));
    font-family: var(--font-body, 'Manrope', sans-serif);
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--t-fast) ease;
    text-shadow: none;
}

.pp-btn--primary {
    background: linear-gradient(180deg,
        var(--gold-pale, var(--gold-pale)) 0%,
        var(--gold-bright, var(--gold-bright)) 40%,
        var(--gold, var(--gold)) 100%);
    color: var(--bg-deepest, var(--bg-deepest));
    border-color: rgba(0, 0, 0, 0.25);
    text-shadow: 0 1px 0 rgba(255, 230, 180, 0.45);
    box-shadow:
        0 3px 8px rgba(0, 0, 0, 0.25),
        inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.pp-btn--primary:hover {
    transform: translateY(-1px);
    box-shadow:
        0 5px 12px rgba(184, 137, 61, 0.40),
        inset 0 1px 0 rgba(255, 255, 255, 0.70);
}

.pp-btn--ghost {
    background: transparent;
    color: var(--gold-deep, var(--gold-deep));
    border-color: var(--gold-deep, var(--gold-deep));
}

.pp-btn--ghost:hover {
    background: rgba(184, 137, 61, 0.15);
    color: var(--accent-ink, var(--accent-ink));
}

/* ---------- Notice / inline-banner inside parchment-card ---------- */

.pp-notice {
    margin: 0 0 var(--space-4, var(--space-4));
    padding: var(--space-3, var(--space-3)) var(--space-4, var(--space-4));
    background: rgba(184, 137, 61, 0.10);
    border-left: 4px solid var(--gold, var(--gold));
    border-radius: 0 var(--radius-sm, var(--radius-sm)) var(--radius-sm, var(--radius-sm)) 0;
    color: var(--text-on-parchment, #2A1F0E);
    position: relative;
    z-index: 2;
}

.pp-notice--warning {
    background: rgba(198, 138, 43, 0.12);
    border-left-color: var(--status-warning, var(--status-warning));
}

.pp-notice--error {
    background: rgba(178, 59, 59, 0.10);
    border-left-color: var(--status-error, var(--status-error));
    color: var(--accent-bordeaux, var(--accent-bordeaux));
}

.pp-notice--success {
    background: rgba(107, 159, 77, 0.12);
    border-left-color: var(--status-success, var(--status-success));
}

.pp-notice strong:first-child {
    display: block;
    margin-bottom: var(--space-1);
    font-size: 0.92rem;
    color: var(--gold-deep, var(--gold-deep));
}
