/* ========================================
   TOKENS
   Define your design decisions here.
   Everything else in this file should
   reference these tokens with var().
   ======================================== */
:root {
    /* COLORS */
    --bg-color: #ffffff;
    --surface-color: #f5f5f5;

    --text-color: #111111;
    --text-muted: #555555;

    --primary-color: #1f7a4c;
    --accent-color: #22c55e;

    --link-color: #1a73e8;
    --link-hover-color: #1558b0;

    --border-color: #e5e5e5;

    /* SPACING (normalized scale) */
    --space-unit: 8px;

    --space-xs: calc(var(--space-unit) * 0.5);
    --space-sm: var(--space-unit);
    --space-md: calc(var(--space-unit) * 2);
    --space-lg: calc(var(--space-unit) * 3);
    --space-xl: calc(var(--space-unit) * 4);

    /* TYPOGRAPHY */
    --font-sans: system-ui, -apple-system, "Segoe UI", Arial, sans-serif;

    --font-size-sm: 0.875rem;
    --font-size-md: 1rem;
    --font-size-lg: 1.25rem;

    --line-height: 1.5;

    /* RADIUS */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
}

/* ========================================
   RESET
   ======================================== */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ========================================
   BASE STYLES
   ======================================== */
body {
    font-family: var(--font-sans);
    font-size: var(--font-size-md);
    line-height: var(--line-height);

    color: var(--text-color);
    background-color: var(--bg-color);

    padding: clamp(var(--space-sm), 2vw, var(--space-xl));

    a {
        color: var(--link-color);

        &:hover {
            color: var(--link-hover-color);
        }
    }
}

/* ========================================
   NAVIGATION
   ======================================== */
.site-nav {
    padding: var(--space-md) var(--space-lg);
    margin-bottom: var(--space-lg);

    background-color: var(--surface-color);
    border-bottom: 1px solid var(--border-color);
}

/* ========================================
   BOARD HEADER
   ======================================== */
.board-header {
    text-align: center;
    margin-bottom: var(--space-lg);
    padding: var(--space-md);

    h1 {
        font-size: clamp(1.75rem, 4vw, 2.75rem);
        line-height: 1.2;
    }

    p {
        color: var(--text-muted);
        margin-bottom: var(--space-sm);
    }
}

/* ========================================
   CARD GROUP
   ======================================== */
.card-group {
    margin-bottom: var(--space-lg);

    h2 {
        font-size: clamp(var(--font-size-md), 3vw, var(--font-size-lg));
        line-height: var(--line-height);
        margin-bottom: var(--space-md);
        color: var(--text-color);
    }
}

/* ========================================
   CARDS GRID
   ======================================== */
.cards {
    display: grid;
    gap: var(--space-md);

    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

/* ========================================
   INDIVIDUAL CARD
   ======================================== */
.card {
    background: var(--surface-color, #ffffff);
    padding: var(--space-md);
    border-radius: var(--radius-lg);

    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);

    display: flex;
    flex-direction: column;
    gap: var(--space-sm);

    transition: transform 0.2s ease, box-shadow 0.2s ease;

    &:hover {
        transform: translateY(-2px);
        box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
    }

    .card-tag {
        font-size: var(--font-size-sm);
        padding: var(--space-xs) var(--space-sm);
        background: var(--accent-color);
        color: #fff;
        border-radius: var(--radius-sm);
        width: fit-content;
    }

    h3 {
        font-size: clamp(1.1rem, 2vw, 1.4rem);
    }

    p {
        font-size: var(--font-size-sm);
        color: var(--text-muted);
    }

    .card-meta {
        margin-top: auto;
        display: flex;
        justify-content: space-between;

        span {
            font-size: var(--font-size-sm);
            color: var(--text-muted);
        }

        a {
            font-size: var(--font-size-sm);
        }
    }
}

/* ========================================
   FOOTER
   ======================================== */
.board-footer {
    text-align: center;
    margin-top: var(--space-lg);
    padding: var(--space-md);
    color: var(--text-muted);
    border-top: 1px solid var(--border-color);
}