/* ===== CSS VARIABLES ===== */
:root {
    /* Colors - Light Theme */
    --color-accent: #eeee55;
    --color-border: #444444;
    --color-primary: #1f1f1f;
    --color-tertiary: #6c757d;
    --color-secondary: #3f3f3f;
    --color-quaternary: #b0b0b0;
    --color-background: #fdf9ec;
    --color-accent-hover: #dddd00;
    --color-accent-shadow: #eeee5555;
    --color-background-tertiary: #eee9d6;
    --color-background-secondary: #f4f0e2;

    /* Dark Theme Colors */
    --color-dark-primary: #fdf9ec;
    --color-dark-tertiary: #b0b0b0;
    --color-dark-secondary: #d9d6ca;
    --color-dark-background: #1f1f1f;
    --color-dark-accent-shadow: #222222;
    --color-dark-background-tertiary: #444444;
    --color-dark-background-secondary: #333333;

    /* Typography */
    --font-weight-thin: 100;
    --font-weight-extra-light: 200;
    --font-weight-light: 300;
    --font-weight-semi-light: 350;
    --font-weight-regular: 400;
    --font-weight-semi-medium: 450;
    --font-weight-medium: 500;
    --font-weight-semi-bold: 600;
    --font-weight-bold: 700;
    --font-weight-extra-bold: 800;
    --font-weight-black: 900;
    --font-family: "Inter", sans-serif;
    --font-family-mono: "JetBrains Mono", monospace;

    /* Spacing */
    --spacing-xxs: 0.05em;
    --spacing-xs: 0.25em;
    --spacing-sm: 0.5em;
    --spacing-md: 1em;
    --spacing-lg: 1.5em;
    --spacing-xl: 2em;
    --spacing-2xl: 2.5em;
    --spacing-3xl: 5em;

    /* Sizes */
    --max-width: 50em;
    --icon-size: 1.25em;
    --avatar-size: 2.75em;
    --border-radius: 0.35em;
    --max-width-caption: 30em;
    --border-radius-full: 9999px;
    --border-radius-medium: 0.5em;

    /* Font Sizes */
    --font-size-xs: 0.75em;
    --font-size-sm: 0.85em;
    --font-size-base: 1em;
    --font-size-md: 1.15em;
    --font-size-lg: 1.25em;
    --font-size-xl: 1.35em;
    --font-size-2xl: 1.5em;
    --font-size-3xl: 2em;
    --font-size-4xl: 2.5em;

    /* Line Heights */
    --line-height-tight: 1.25em;
    --line-height-normal: 1.5em;
    --line-height-relaxed: 1.75em;

    /* Padding & Margin Values */
    --padding-badge: 1.75em;
    --padding-button: 0.75em;

    /* Transitions */
    --transition-fast: 0.25s ease-in-out;
}

/* ===== FONT FACES ===== */
@font-face {
    font-display: swap;
    font-family: "Inter";
    src: url(/asset/resource/font/inter-variable.ttf);
}
@font-face {
    font-display: swap;
    font-family: "JetBrains Mono";
    src: url(/n/asset/font/jetbrainsmono-variable.ttf);
}

/* ===== BASE STYLES ===== */
body {
    color: var(--color-primary);
    font-family: var(--font-family);
    background: var(--color-background);
    font-weight: var(--font-weight-regular);
}

/* ===== HEADER ===== */
header {
    margin: 0 auto;
    max-width: var(--max-width);
    padding: var(--spacing-3xl) var(--spacing-lg) var(--spacing-lg) var(--spacing-lg);
}

/* Badge Component */
header .badge {
    text-decoration: none;
    display: inline-block;
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    background: var(--color-accent);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-medium);
    border-radius: var(--border-radius-full);
    border: 1px solid var(--color-accent-hover);
    transition: background var(--transition-fast);
    padding: var(--spacing-md) var(--padding-badge);
    box-shadow: 0 4px 8px var(--color-accent-shadow);
}

header .badge:hover {
    background: var(--color-accent-hover);
}

header .badge svg {
    fill: currentColor;
    vertical-align: middle;
    width: var(--icon-size);
    height: var(--icon-size);
    margin-right: var(--spacing-sm);
}

/* Header Typography */
header h1 {
    letter-spacing: -0.025em;
    font-size: var(--font-size-4xl);
    line-height: var(--line-height-tight);
    font-weight: var(--font-weight-semi-bold);
}

header p {
    letter-spacing: -0.025em;
    color: var(--color-tertiary);
    font-size: var(--font-size-lg);
    margin-bottom: var(--spacing-xl);
    line-height: var(--line-height-normal);
}

/* Meta Information */
header .meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-sm);
    font-size: var(--font-size-sm);
    justify-content: space-between;
    line-height: var(--line-height-normal);
}

header .meta .meta-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

header .meta .meta-user a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-primary);
    text-underline-offset: var(--spacing-xs);
}

header .meta .meta-user img {
    object-fit: cover;
    aspect-ratio: 1 / 1;
    object-position: center;
    width: var(--avatar-size);
    height: var(--avatar-size);
    border-radius: var(--border-radius-full);
}

header .meta .meta-read {
    color: var(--color-tertiary);
}

header .meta .meta-read span {
    display: inline-block;
}

/* Action Button */
header .meta .action {
    cursor: pointer;
    position: relative;
    width: var(--avatar-size);
    height: var(--avatar-size);
    border-radius: var(--border-radius-full);
    background: var(--color-background-secondary);
    transition: background var(--transition-fast);
}

header .meta .action:hover {
    background: var(--color-background-tertiary);
}

header .meta .action svg {
    fill: currentColor;
    vertical-align: middle;
    margin: -0.025em 0 0 -0.025em;
    padding: var(--padding-button);
}

header .meta .action span {
    left: 50%;
    position: absolute;
    color: var(--color-tertiary);
    transform: translate(-50%, -125%);
}

/* ===== MAIN CONTENT ===== */
main {
    margin: 0 auto;
    padding: var(--spacing-lg);
    max-width: var(--max-width);
}

/* Figure and Images */
main figure {
    margin: 0 auto;
    margin-bottom: var(--spacing-lg);
}

main figure img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 4 / 3;
    object-position: center;
    margin-bottom: var(--spacing-md);
    border-radius: var(--border-radius-medium);
}

main figure figcaption {
    margin: 0 auto;
    text-align: center;
    font-style: italic;
    color: var(--color-tertiary);
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-sm);
    max-width: var(--max-width-caption);
    line-height: var(--line-height-normal);
}

main figure figcaption a {
    text-decoration: underline;
    color: var(--color-tertiary);
    text-underline-offset: var(--spacing-xs);
}

/* Content Styles */
main .content {
    letter-spacing: 0.0025em;
    font-size: var(--font-size-md);
    line-height: var(--line-height-relaxed);
    font-weight: var(--font-weight-semi-light);
}

main .content p,
main .content li {
    color: var(--color-secondary);
}

main .content a {
    text-decoration: underline;
    color: var(--color-primary);
    text-underline-offset: var(--spacing-xs);
    font-weight: var(--font-weight-semi-medium);
}

main .content p:first-child {
    margin-top: var(--spacing-2xl);
}

main .content p:not(:last-child) {
    margin-bottom: var(--spacing-lg);
}

main .content h2,
main .content h3 {
    letter-spacing: -0.025em;
    margin-bottom: var(--spacing-sm);
    line-height: var(--line-height-tight);
    font-weight: var(--font-weight-medium);
}

main .content h2 {
    margin-top: var(--spacing-xl);
    font-size: var(--font-size-2xl);
}

main .content h3 {
    margin-top: var(--spacing-lg);
    font-size: var(--font-size-base);
}

main .content strong {
    color: var(--color-primary);
    font-weight: var(--font-weight-semi-medium);
}

main .content code {
    display: inline-block;
    font-size: var(--font-size-sm);
    padding-inline: var(--spacing-sm);
    border-radius: var(--border-radius);
    font-family: var(--font-family-mono);
    line-height: var(--line-height-normal);
    background: var(--color-background-secondary);
    border: 1px solid var(--color-background-tertiary);
}

/* Lists */
main .content ul,
main .content ol {
    padding-left: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

main .content ul li,
main .content ol li {
    margin-bottom: var(--spacing-xs);
}

main .content ul li::marker,
main .content ol li::marker {
    color: var(--color-secondary);
}

/* Category */
main .category {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    font-family: var(--font-family);
    margin-bottom: var(--spacing-2xl);
}

/* Card Grid */
main .content:has(.card) {
    display: grid;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
    grid-template-columns: repeat(2, 1fr);
}

main .card:nth-of-type(1) {
    grid-column: span 2;
}

main .card:nth-of-type(1) img {
    aspect-ratio: 16 / 9;
}

main .content:has(.card) span {
    grid-column: span 2;
    font-size: var(--font-size-lg);
    font-family: var(--font-family);
    font-weight: var(--font-weight-medium);
}

/* Card Styles */
main a.card {
    text-decoration-color: transparent;
    transition: text-decoration-color var(--transition-fast);
}

main a.card:hover {
    text-decoration-color: var(--color-primary);
}

main .card img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 4 / 3;
    margin-bottom: var(--spacing-md);
    border-radius: var(--border-radius);
    transition: filter var(--transition-fast);
}

main .card:hover img {
    filter: brightness(1.075);
}

main .card h2 {
    overflow: hidden;
    display: -webkit-box;
    margin-bottom: 0.75em;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
}

/* ===== FOOTER ===== */
footer {
    margin: 0 auto;
    text-align: center;
    color: var(--color-tertiary);
    max-width: var(--max-width);
    font-family: var(--font-family);
    padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-3xl) var(--spacing-lg);
}

footer .action {
    display: flex;
    justify-content: center;
    margin-bottom: var(--spacing-lg);
}

footer .action button {
    border: none;
    display: flex;
    cursor: pointer;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    background: var(--color-accent);
    font-weight: var(--font-weight-medium);
    border-radius: var(--border-radius-full);
    border: 1px solid var(--color-accent-hover);
    padding: var(--spacing-md) var(--spacing-lg);
    transition: background var(--transition-fast);
    box-shadow: 0 4px 8px var(--color-accent-shadow);
}

footer .action button:hover {
    background: var(--color-accent-hover);
}

footer .action button svg {
    width: var(--icon-size);
    height: var(--icon-size);
}

footer p {
    margin-top: var(--spacing-lg);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-normal);
}

/* ===== RESPONSIVE DESIGN ===== */
@media (max-width: 500px) {
    header {
        padding: var(--spacing-lg) var(--spacing-md) var(--spacing-lg) var(--spacing-md);
    }

    header .badge {
        font-size: var(--font-size-xs);
    }

    header h1 {
        font-size: var(--font-size-3xl);
    }

    header p {
        font-size: var(--font-size-base);
    }

    header .meta {
        align-items: start;
        flex-direction: column;
    }

    header .meta .action {
        margin-top: var(--spacing-sm);
    }

    header .meta .action span {
        top: 50%;
        right: 0;
        transform: translate(125%, -50%);
    }

    main {
        padding: var(--spacing-lg) var(--spacing-md);
    }

    main .content {
        font-size: var(--font-size-base);
    }

    main .content h2 {
        font-size: var(--font-size-xl);
    }

    main .card:nth-of-type(1) img {
        aspect-ratio: 4 / 3;
    }

    main .content:has(.card) a {
        grid-column: span 2;
    }

    main .content:has(.card) h2 {
        font-size: var(--font-size-base);
    }

    footer {
        padding: var(--spacing-lg) var(--spacing-md) var(--spacing-lg) var(--spacing-md);
    }

    footer .action button {
        font-size: var(--font-size-xs);
    }
}

/* ===== DARK MODE ===== */
@media (prefers-color-scheme: dark) {
    :root {
        --color-primary: var(--color-dark-primary);
        --color-tertiary: var(--color-dark-tertiary);
        --color-secondary: var(--color-dark-secondary);
        --color-background: var(--color-dark-background);
        --color-border: var(--color-dark-background-tertiary);
        --color-accent: var(--color-dark-background-secondary);
        --color-accent-shadow: var(--color-dark-accent-shadow);
        --color-accent-hover: var(--color-dark-background-tertiary);
        --color-background-tertiary: var(--color-dark-background-tertiary);
        --color-background-secondary: var(--color-dark-background-secondary);
    }

    main .content ul li::marker {
        color: var(--color-primary);
    }

    main .card img {
        filter: brightness(1.05);
    }
}
