/* ===========================================================================
 * pages.css — sub-pages (privacy, terms, about, contact) + article body
 *
 * Reuses tokens from main.css. Light theme, apk1.com-style cards.
 * ========================================================================= */


/* ----- Sub-page article body ---------------------------------------------- */
body.page .content {
    max-width: 760px;
    background: var(--c-surface);
    border-radius: var(--rd-box);
    padding: clamp(var(--sp-5), 4vw, var(--sp-7));
    margin-block: var(--sp-6);
    box-shadow: var(--sw-card);
}
/* Contact form already has its own card — drop the wrapping card. */
body.page .content:has(.contact-form) {
    background: transparent;
    box-shadow: none;
    padding: 0;
    margin-block: 0;
}

body.page .content > h1 {
    font-size: var(--fs-xxl);
    text-align: start;
    margin-block: 0 var(--sp-5);
    color: var(--c-text);
    letter-spacing: -0.02em;
    line-height: 1.1;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}
body.page .content > h1::before {
    content: "";
    flex-shrink: 0;
    width: 10px;
    height: 32px;
    background: var(--c-primary);
    border-radius: 3px;
    box-shadow: 0 2px 8px rgba(185, 233, 46, 0.4);
}

body.page .content h2,
body.page .content h3 {
    margin-block: var(--sp-6) var(--sp-3);
    color: var(--c-text);
    letter-spacing: -0.01em;
}
body.page .content h2 { font-size: var(--fs-xl); }
body.page .content h3 { font-size: var(--fs-lg); }

body.page .content p,
body.page .content li {
    font-size: var(--fs-md);
    line-height: var(--lh-body);
    color: var(--c-text-soft);
}
body.page .content ul,
body.page .content ol {
    padding-inline-start: var(--sp-6);
    margin-block: var(--sp-4);
}
body.page .content ul li {
    list-style: disc;
    margin-block: var(--sp-2);
}
body.page .content ul li::marker { color: var(--c-second); }
body.page .content ol li {
    list-style: decimal;
    margin-block: var(--sp-2);
}
body.page .content ol li::marker {
    color: var(--c-second);
    font-weight: 600;
    font-family: var(--font-latin);
}

body.page .content a {
    color: var(--c-second);
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-thickness: 1px;
    text-decoration-color: var(--c-second-ring);
    transition: color var(--t-fast), text-decoration-color var(--t-fast);
}
body.page .content a:hover {
    color: var(--c-second-hover);
    text-decoration-color: var(--c-second-hover);
    text-decoration-thickness: 2px;
}


/* ----- Article body (front-page long-form .content) ---------------------- */
.content figure { margin: var(--sp-6) 0; text-align: center; }
.content figure figcaption {
    margin-block-start: var(--sp-2);
    color: var(--c-text-muted);
    font-size: var(--fs-xs);
    font-style: italic;
}
.content ul,
.content ol {
    padding-inline-start: var(--sp-6);
    margin-block: var(--sp-4);
}
.content ul li { list-style: disc; margin-block: var(--sp-2); color: var(--c-text-soft); }
.content ul li::marker { color: var(--c-second); }
.content ol li { list-style: decimal; margin-block: var(--sp-2); color: var(--c-text-soft); }
.content ol li::marker { color: var(--c-second); font-family: var(--font-latin); }
.content a {
    color: var(--c-second);
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-thickness: 1px;
    text-decoration-color: var(--c-second-ring);
    font-weight: 600;
    transition: color var(--t-fast), text-decoration-color var(--t-fast);
}
.content a:hover {
    color: var(--c-second-hover);
    text-decoration-color: var(--c-second);
}

/* CTAs inside .content keep their on-accent label (dark text on lime). */
.content .btn,
.content a.btn,
.content button.btn {
    color: var(--c-text);
    text-decoration: none;
    font-weight: 700;
}
.content .btn:hover,
.content a.btn:hover,
.content button.btn:hover,
.content .btn:focus-visible {
    color: var(--c-text);
    text-decoration: none;
}


/* ----- Contact form ------------------------------------------------------- */
.contact-form {
    max-width: 640px;
    margin-inline: auto;
    margin-block-start: var(--sp-6);
    display: grid;
    gap: var(--sp-5);
    padding: clamp(var(--sp-5), 3vw, var(--sp-6));
    background: var(--c-surface);
    border-radius: var(--rd-box);
    box-shadow: var(--sw-card);
}
.contact-form__row {
    display: grid;
    gap: 6px;
}
.contact-form label {
    font-weight: 700;
    color: var(--c-text);
    font-size: var(--fs-sm);
}
.contact-form input,
.contact-form textarea {
    padding: 12px 14px;
    border: 1px solid var(--c-border-2);
    border-radius: var(--rd-md);
    background: var(--c-body-tone);
    transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
    font: inherit;
    color: var(--c-text);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: var(--c-text-muted); }
.contact-form input:hover,
.contact-form textarea:hover { border-color: var(--c-text-muted); }
.contact-form input:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: var(--c-second);
    background: var(--c-surface);
    box-shadow: 0 0 0 4px var(--c-second-ring);
}
.contact-form textarea { resize: vertical; min-height: 150px; }
.contact-form button { justify-self: start; margin-block-start: var(--sp-2); }

.contact-form__hp {
    position: absolute !important;
    inset-inline-start: -10000px;
    width: 1px; height: 1px;
    overflow: hidden;
}

.form-notice {
    margin: var(--sp-5) auto;
    max-width: 640px;
    padding: var(--sp-3) var(--sp-4);
    border-radius: var(--rd-md);
    font-weight: 600;
    border: 1px solid;
    background: var(--c-surface);
    font-size: var(--fs-sm);
}
.form-notice--ok {
    border-color: rgba(25, 179, 120, 0.35);
    color: #138255;
    background: rgba(25, 179, 120, 0.06);
}
.form-notice--err {
    border-color: rgba(226, 62, 22, 0.35);
    color: var(--c-red);
    background: rgba(226, 62, 22, 0.05);
}


/* ----- Article body (Posts content rendered on front-page) ---------------- */
.article-body { max-width: 760px; margin-inline: auto; }

.article-body__content {
    font-size: var(--fs-md);
    line-height: var(--lh-body);
    color: var(--c-text-soft);
}
.article-body__content > * + * { margin-block-start: var(--sp-4); }

.article-body__content h2,
.article-body__content h3,
.article-body__content h4 {
    margin-block: var(--sp-6) var(--sp-3);
    color: var(--c-text);
    letter-spacing: -0.01em;
}
.article-body__content h2 { font-size: var(--fs-xl); }
.article-body__content h3 { font-size: var(--fs-lg); }
.article-body__content h4 { font-size: var(--fs-md); }

.article-body__content p { line-height: var(--lh-body); }
.article-body__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--rd-lg);
    box-shadow: var(--sw-card);
    margin-inline: auto;
    display: block;
}
.article-body__content figure {
    margin: var(--sp-6) 0;
    text-align: center;
}
.article-body__content figure figcaption {
    margin-block-start: var(--sp-2);
    color: var(--c-text-muted);
    font-size: var(--fs-xs);
    font-style: italic;
}
.article-body__content ul,
.article-body__content ol {
    padding-inline-start: var(--sp-6);
    margin-block: var(--sp-4);
}
.article-body__content ul li { list-style: disc; margin-block: var(--sp-2); }
.article-body__content ul li::marker { color: var(--c-second); }
.article-body__content ol li { list-style: decimal; margin-block: var(--sp-2); }
.article-body__content ol li::marker { color: var(--c-second); font-family: var(--font-latin); }
.article-body__content a {
    color: var(--c-second);
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-thickness: 1px;
    text-decoration-color: var(--c-second-ring);
    font-weight: 600;
    transition: color var(--t-fast), text-decoration-color var(--t-fast);
}
.article-body__content a:hover {
    color: var(--c-second-hover);
    text-decoration-color: var(--c-second);
}

.article-body__content .alignleft   { float: left;  margin-inline-end: var(--sp-5); margin-block-end: var(--sp-3); }
.article-body__content .alignright  { float: right; margin-inline-start: var(--sp-5); margin-block-end: var(--sp-3); }
.article-body__content .aligncenter { display: block; margin-inline: auto; }
.article-body__content .alignwide   { max-width: 1080px; margin-inline: auto; }
.article-body__content .alignfull   { max-width: none; margin-inline: calc(50% - 50vw); width: 100vw; }

.article-body__content blockquote {
    margin: var(--sp-6) 0;
    padding: var(--sp-4) var(--sp-5);
    border-inline-start: 4px solid var(--c-primary);
    background: var(--c-body-tone);
    border-radius: var(--rd-md);
    font-style: italic;
    color: var(--c-text);
}
.article-body__content code {
    background: var(--c-body-tone);
    padding: 2px 6px;
    border-radius: var(--rd-mini);
    font-size: 0.9em;
    color: var(--c-second);
    font-weight: 600;
    font-family: var(--font-latin);
}
.article-body__content pre {
    background: var(--c-text);
    color: var(--c-body);
    padding: var(--sp-5);
    border-radius: var(--rd-lg);
    overflow-x: auto;
    box-shadow: var(--sw-card);
    font-family: var(--font-latin);
}
.article-body__content pre code {
    background: transparent;
    color: inherit;
    padding: 0;
}
