/* ═══════════════════════════════════════════════════════════════
   THEME
   ═══════════════════════════════════════════════════════════════ */
:root {
    /* ─── Colors ─── */
    --color-bg-deep:        #0a0508;           /* Darkest background */
    --color-bg-panel:       #1a0d12;           /* Panel background */
    --color-bg-panel-alt:   #120a0d;           /* Alternate panel bg */

    --color-wood-dark:      #2d1810;           /* Dark wood tone */
    --color-wood-mid:       #4a2820;           /* Mid wood tone */
    --color-wood-light:     #6b3d30;           /* Light wood tone */

    --color-brass:          #b8860b;           /* Primary brass/gold */
    --color-brass-light:    #daa520;           /* Highlight brass */
    --color-brass-dark:     #8b6914;           /* Shadow brass */

    --color-accent:         #9b59b6;           /* Purple accent */
    --color-accent-bright:  #bb77d6;           /* Bright purple */
    --color-accent-dim:     #6b3a7d;           /* Dim purple */

    --color-text:           #d4c4a8;           /* Primary text */
    --color-text-dim:       #8a7a60;           /* Secondary text */
    --color-text-bright:    #f0e6d0;           /* Emphasized text */

    --color-link:           var(--color-accent-bright);
    --color-link-hover:     #e0a0f0;
    --color-link-visited:   var(--color-accent-dim);

    /* ─── Typography ─── */
    --font-display:         'IM Fell English', Georgia, serif;
    --font-body:            'JetBrains Mono', 'Courier New', monospace;

    --size-base:            16px;
    --size-small:           0.875rem;
    --size-large:           1.25rem;
    --size-xlarge:          1.75rem;
    --size-display:         2.5rem;

    --line-height:          1.6;
    --line-height-tight:    1.3;

    /* ─── Spacing ─── */
    --space-xs:             0.25rem;
    --space-sm:             0.5rem;
    --space-md:             1rem;
    --space-lg:             2rem;
    --space-xl:             4rem;

    /* ─── Borders & Decorations ─── */
    --border-width:         2px;
    --border-color:         var(--color-brass-dark);
    --border-radius:        4px;

    /* Panel borders - can be upgraded to border-image */
    --panel-border:         var(--border-width) solid var(--color-brass);
    --panel-border-inset:   1px solid var(--color-brass-dark);

    /* ─── Shadows ─── */
    --shadow-subtle:        0 2px 4px rgba(0, 0, 0, 0.3);
    --shadow-lifted:        0 4px 12px rgba(0, 0, 0, 0.5);
    --shadow-inset:         inset 0 2px 8px rgba(0, 0, 0, 0.4);
    --shadow-glow:          0 0 20px rgba(155, 89, 182, 0.3);

    /* ─── Textures (URLs go here when you have assets) ─── */
    --texture-bg:           none;  /* url('assets/bg-dark.jpg') */
    --texture-wood:         none;  /* url('assets/wood-grain.jpg') */
    --texture-paper:        none;  /* url('assets/paper.jpg') */
    --texture-noise:        none;  /* url('assets/noise.png') */

    /* ─── Layout ─── */
    --content-width:        800px;
    --panel-width:          400px;
    --panel-min-width:      280px;
}

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

html {
    font-size: var(--size-base);
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: var(--line-height);
    color: var(--color-text);
    background-color: var(--color-bg-deep);
    background-image: var(--texture-bg);
    background-size: cover;
    background-attachment: fixed;
    background-position: center;
    min-height: 100vh;
}

/* ═══════════════════════════════════════════════════════════════
   TYPOGRAPHY
   ═══════════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: normal;
    line-height: var(--line-height-tight);
    color: var(--color-text-bright);
}

h1 { font-size: var(--size-display); }
h2 { font-size: var(--size-xlarge); }
h3 { font-size: var(--size-large); }

a {
    color: var(--color-link);
    text-decoration: none;
    transition: color 0.2s ease, text-shadow 0.2s ease;
}

a:hover {
    color: var(--color-link-hover);
    text-shadow: 0 0 8px var(--color-accent);
}

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

/* Terminal-style text */
.terminal {
    font-family: var(--font-body);
    font-size: var(--size-small);
    color: var(--color-accent-bright);
}

.terminal::before {
    content: '› ';
    color: var(--color-brass);
}

/* ═══════════════════════════════════════════════════════════════
   LAYOUT CONTAINERS
   ═══════════════════════════════════════════════════════════════ */
.page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-lg);
}

.page--centered {
    justify-content: center;
}

.content {
    width: 100%;
    max-width: var(--content-width);
}

/* Grid for multiple panels side-by-side */
.panel-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--panel-min-width), 1fr));
    gap: var(--space-lg);
}

/* ═══════════════════════════════════════════════════════════════
   PANELS (Core modular unit)
   Like your VCV modules - self-contained visual units
   ═══════════════════════════════════════════════════════════════ */
.panel {
    background-color: var(--color-bg-panel);
    background-image: var(--texture-wood);
    background-size: cover;
    background-position: center;
    border: var(--panel-border);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-lifted), var(--shadow-inset);
    padding: var(--space-lg);
    position: relative;
}

/* Brass corner accents - placeholder for SVG/images */
.panel--cornered::before,
.panel--cornered::after {
    content: '';
    position: absolute;
    width: 24px;
    height: 24px;
    border-color: var(--color-brass);
    border-style: solid;
}

.panel--cornered::before {
    top: 8px;
    left: 8px;
    border-width: 2px 0 0 2px;
}

.panel--cornered::after {
    bottom: 8px;
    right: 8px;
    border-width: 0 2px 2px 0;
}

.panel__header {
    text-align: center;
    padding-bottom: var(--space-md);
    margin-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-brass-dark);
}

.panel__title {
    margin-bottom: var(--space-xs);
}

.panel__subtitle {
    font-size: var(--size-small);
    color: var(--color-text-dim);
}

.panel__content {
    /* Flexible content area */
}

.panel__footer {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-brass-dark);
    font-size: var(--size-small);
    color: var(--color-text-dim);
}

/* ═══════════════════════════════════════════════════════════════
   LINK LIST (Grimoire entries)
   ═══════════════════════════════════════════════════════════════ */
.link-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.link-list__item {
    /* Individual entry */
}

.link-list__link {
    display: block;
    padding: var(--space-md);
    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-brass-dark);
    border-radius: var(--border-radius);
    transition: all 0.2s ease;
}

.link-list__link:hover {
    background-color: rgba(155, 89, 182, 0.1);
    border-color: var(--color-brass);
    box-shadow: var(--shadow-glow);
    transform: translateX(4px);
}

.link-list__link:visited {
    color: var(--color-link);  /* Override default visited */
}

.link-list__link:visited:hover {
    color: var(--color-link-hover);
}

/* ═══════════════════════════════════════════════════════════════
   PROJECT CARDS
   ═══════════════════════════════════════════════════════════════ */
.card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-md);
}

.card {
    display: block;
    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-brass-dark);
    border-radius: var(--border-radius);
    padding: var(--space-md);
    transition: all 0.2s ease;
    text-decoration: none;
    color: inherit;
}

.card:hover {
    background-color: rgba(155, 89, 182, 0.1);
    border-color: var(--color-brass);
    box-shadow: var(--shadow-glow);
    transform: translateY(-4px);
}

.card:visited {
    color: inherit;
}

.card__title {
    font-family: var(--font-display);
    font-size: var(--size-large);
    color: var(--color-text-bright);
    margin-bottom: var(--space-sm);
}

.card__description {
    font-size: var(--size-small);
    color: var(--color-text-dim);
    line-height: var(--line-height);
}

.card__meta {
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px solid var(--color-brass-dark);
    font-size: var(--size-small);
    color: var(--color-brass);
}

/* ═══════════════════════════════════════════════════════════════
   DECORATIVE ELEMENTS
   ═══════════════════════════════════════════════════════════════ */

/* Horizontal rule - brass line */
.divider {
    border: none;
    height: 1px;
    background: linear-gradient(
        90deg,
        transparent,
        var(--color-brass-dark) 20%,
        var(--color-brass) 50%,
        var(--color-brass-dark) 80%,
        transparent
    );
    margin: var(--space-lg) 0;
}

/* Decorative sigil/glyph placeholder */
.sigil {
    display: inline-block;
    width: 48px;
    height: 48px;
    color: var(--color-brass);
    text-align: center;
    line-height: 48px;
    font-size: 2rem;
}

/* Vignette overlay for aged/worn effect */
.vignette {
    position: relative;
}

.vignette::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(
        ellipse at center,
        transparent 40%,
        rgba(0, 0, 0, 0.4) 100%
    );
}

/* ═══════════════════════════════════════════════════════════════
   UTILITY CLASSES
   ═══════════════════════════════════════════════════════════════ */
.text-center { text-align: center; }
.text-dim { color: var(--color-text-dim); }
.text-bright { color: var(--color-text-bright); }
.text-accent { color: var(--color-accent-bright); }
.text-brass { color: var(--color-brass); }

.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    :root {
        --size-display: 2rem;
        --space-lg: 1.5rem;
    }

    .page {
        padding: var(--space-md);
    }
}
