/* ============================================================
   CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
    --bg-primary: #0a0a0f;
    --bg-secondary: #12121a;
    --bg-card: #1a1a2e;
    --bg-card-hover: #222240;
    --bg-input: #16162a;
    --text-primary: #e0e0e0;
    --text-secondary: #a0a0b8;
    --text-muted: #606078;
    --accent-green: #00ff88;
    --accent-green-dim: #00cc6a;
    --accent-amber: #ffb000;
    --accent-blue: #4a9eff;
    --accent-purple: #b088ff;
    --accent-red: #ff4466;
    --border-color: #2a2a3e;
    --border-subtle: #1e1e30;
    --shadow: 0 2px 8px rgba(0,0,0,0.3);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
    --radius: 8px;
    --radius-sm: 4px;
    --radius-lg: 12px;
    --transition: 0.2s ease;
    --max-width: 1200px;
    --content-width: 800px;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', 'SF Mono', 'Menlo', monospace;
    --font-size-sm: 0.875rem;
    --font-size-base: 1rem;
    --font-size-lg: 1.125rem;
    --font-size-xl: 1.25rem;
    --font-size-2xl: 1.5rem;
    --font-size-3xl: 2rem;
    --font-size-4xl: 2.5rem;
}

[data-theme="light"] {
    --bg-primary: #fafafa;
    --bg-secondary: #ffffff;
    --bg-card: #ffffff;
    --bg-card-hover: #f5f5f5;
    --bg-input: #f0f0f0;
    --text-primary: #1a1a2e;
    --text-secondary: #4a4a5e;
    --text-muted: #8a8a9e;
    --accent-green: #00884a;
    --accent-green-dim: #006638;
    --border-color: #e0e0e0;
    --border-subtle: #eaeaea;
    --shadow: 0 2px 8px rgba(0,0,0,0.08);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
}

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

html { font-size: 16px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    font-family: var(--font-body);
    background: var(--bg-primary);
    color: var(--text-primary);
    line-height: 1.7;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    transition: background-color var(--transition), color var(--transition);
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container { width:100%; max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; }
.content-width { max-width:var(--content-width); margin:0 auto; }
main { flex:1; padding:2rem 0; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header {
    border-bottom:1px solid var(--border-color);
    padding:1rem 0;
    position:sticky;
    top:0;
    z-index:100;
    backdrop-filter:blur(10px);
    background:rgba(18,18,26,0.9);
}
[data-theme="light"] .site-header { background:rgba(255,255,255,0.9); }

.nav { display:flex; align-items:center; justify-content:space-between; gap:2rem; }

.nav-brand {
    font-family:var(--font-mono);
    font-size:var(--font-size-lg);
    color:var(--accent-green);
    text-decoration:none;
    font-weight:600;
}
.nav-brand:hover { text-shadow:0 0 8px rgba(0,255,136,0.4); }

.nav-links { display:flex; list-style:none; gap:0.25rem; align-items:center; }
.nav-links a { color:var(--text-secondary); text-decoration:none; padding:0.5rem 0.75rem; border-radius:var(--radius-sm); font-size:var(--font-size-sm); transition:all var(--transition); }
.nav-links a:hover, .nav-links a.active { color:var(--accent-green); background:rgba(0,255,136,0.08); }

.nav-toggle { display:none; background:none; border:none; color:var(--text-primary); font-size:1.5rem; cursor:pointer; }
.theme-toggle { background:none; border:1px solid var(--border-color); border-radius:var(--radius-sm); padding:0.4rem 0.6rem; cursor:pointer; font-size:0.9rem; transition:all var(--transition); }
.theme-toggle:hover { border-color:var(--accent-green); }

@media (max-width:768px) {
    .nav-toggle { display:block; }
    .nav-links {
        display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0;
        background:var(--bg-secondary); border-bottom:1px solid var(--border-color); padding:1rem;
    }
    .nav-links.open { display:flex; }
}

/* ============================================================
   CARDS
   ============================================================ */
.card-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:1.5rem; }

.card {
    background:var(--bg-card);
    border:1px solid var(--border-color);
    border-radius:var(--radius);
    padding:1.5rem;
    transition:all var(--transition);
}
.card:hover { background:var(--bg-card-hover); border-color:var(--accent-green); box-shadow:0 0 0 1px var(--accent-green),var(--shadow-lg); transform:translateY(-2px); }

.card-body { display:flex; flex-direction:column; gap:0.5rem; }
.card-img { width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:var(--radius-sm) var(--radius-sm) 0 0; margin-bottom:0.5rem; }
.card-title { font-size:var(--font-size-xl); }
.card-title a { color:var(--text-primary); text-decoration:none; }
.card-title a:hover { color:var(--accent-green); }
.card-meta { font-size:var(--font-size-sm); color:var(--text-muted); }
.card-description { color:var(--text-secondary); font-size:var(--font-size-sm); line-height:1.6; }
.card-tags { display:flex; flex-wrap:wrap; gap:0.4rem; margin-top:0.5rem; }
.card-links { display:flex; gap:0.5rem; margin-top:0.75rem; }

/* ============================================================
   TAGS / BADGES
   ============================================================ */
.tag {
    display:inline-block;
    font-family:var(--font-mono);
    font-size:0.75rem;
    padding:0.2rem 0.6rem;
    border-radius:var(--radius-sm);
    background:rgba(0,255,136,0.1);
    color:var(--accent-green);
    border:1px solid rgba(0,255,136,0.2);
    text-decoration:none;
    transition:all var(--transition);
}
.tag:hover { background:rgba(0,255,136,0.2); }
.tag-active { background:rgba(0,255,136,0.2) !important; }
.tag-count { opacity:0.7; }

.badge-status {
    font-size:0.7rem;
    padding:0.15rem 0.5rem;
    border-radius:9999px;
    text-transform:uppercase;
    font-weight:600;
    letter-spacing:0.05em;
    font-family:var(--font-mono);
}
.badge-active      { background:rgba(0,255,136,0.15); color:var(--accent-green); }
.badge-completed   { background:rgba(74,158,255,0.15); color:var(--accent-blue); }
.badge-in-progress { background:rgba(255,176,0,0.15); color:var(--accent-amber); }
.badge-archived    { background:rgba(160,160,184,0.15); color:var(--text-muted); }
.badge-published   { background:rgba(0,255,136,0.15); color:var(--accent-green); }
.badge-draft       { background:rgba(255,176,0,0.15); color:var(--accent-amber); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display:inline-flex;
    align-items:center;
    gap:0.5rem;
    padding:0.6rem 1.2rem;
    border:1px solid transparent;
    border-radius:var(--radius-sm);
    font-size:var(--font-size-sm);
    font-weight:600;
    cursor:pointer;
    text-decoration:none;
    transition:all var(--transition);
    font-family:var(--font-body);
}
.btn-primary { background:var(--accent-green); color:#0a0a0f; border-color:var(--accent-green); }
.btn-primary:hover { background:var(--accent-green-dim); box-shadow:0 0 12px rgba(0,255,136,0.3); }
.btn-outline { background:transparent; color:var(--accent-green); border-color:var(--accent-green); }
.btn-outline:hover { background:rgba(0,255,136,0.1); }
.btn-danger { background:transparent; color:var(--accent-red); border-color:var(--accent-red); }
.btn-danger:hover { background:rgba(255,68,102,0.1); }

/* ============================================================
   FORMS
   ============================================================ */
.form-group { display:flex; flex-direction:column; gap:0.4rem; margin-bottom:1rem; }
.form-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1rem; }
label { font-size:var(--font-size-sm); font-weight:600; color:var(--text-secondary); }
.form-control {
    background:var(--bg-input);
    border:1px solid var(--border-color);
    border-radius:var(--radius-sm);
    color:var(--text-primary);
    font-family:var(--font-body);
    font-size:var(--font-size-base);
    padding:0.6rem 0.8rem;
    transition:border-color var(--transition);
    width:100%;
}
.form-control:focus { outline:none; border-color:var(--accent-green); box-shadow:0 0 0 2px rgba(0,255,136,0.15); }
textarea.form-control { resize:vertical; min-height:100px; }
select.form-control { cursor:pointer; }
.form-control small, small { font-size:0.75rem; color:var(--text-muted); }
.form-actions { display:flex; gap:1rem; margin-top:1.5rem; }

/* ============================================================
   ALERTS / FLASH
   ============================================================ */
.alert {
    padding:0.75rem 1rem;
    border-radius:var(--radius-sm);
    border-left:3px solid;
    margin-bottom:1rem;
    font-size:var(--font-size-sm);
}
.alert-success { background:rgba(0,255,136,0.1); border-color:var(--accent-green); color:var(--accent-green); }
.alert-error   { background:rgba(255,68,102,0.1); border-color:var(--accent-red); color:var(--accent-red); }
.alert-info    { background:rgba(74,158,255,0.1); border-color:var(--accent-blue); color:var(--accent-blue); }

/* ============================================================
   BLOG
   ============================================================ */
.tag-filter { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:2rem; }
.post-list-full { display:flex; flex-direction:column; gap:2rem; }
.post-card { border-bottom:1px solid var(--border-subtle); padding-bottom:2rem; }
.post-card:last-child { border-bottom:none; }
.post-date { font-family:var(--font-mono); font-size:var(--font-size-sm); color:var(--text-muted); display:block; margin-bottom:0.25rem; }
.post-card-title { font-size:var(--font-size-2xl); margin-bottom:0.5rem; }
.post-card-title a { color:var(--text-primary); text-decoration:none; }
.post-card-title a:hover { color:var(--accent-green); }
.post-card-excerpt { color:var(--text-secondary); margin-bottom:0.75rem; }
.post-read-more { color:var(--accent-green); text-decoration:none; font-size:var(--font-size-sm); font-weight:600; }

.post-header { margin-bottom:2rem; }
.post-meta { font-family:var(--font-mono); font-size:var(--font-size-sm); color:var(--text-muted); margin-bottom:0.5rem; }
.post-header h1 { font-size:var(--font-size-4xl); line-height:1.2; margin-bottom:1rem; }
.post-tags { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:1rem; }
.post-cover-image { width:100%; border-radius:var(--radius); margin-top:1rem; }
.post-footer { margin-top:3rem; padding-top:2rem; border-top:1px solid var(--border-color); }

.post-list { display:flex; flex-direction:column; gap:0.75rem; }
.post-list-item { display:flex; align-items:baseline; gap:1rem; }
.post-link { color:var(--text-primary); text-decoration:none; }
.post-link:hover { color:var(--accent-green); }

/* ============================================================
   GUESTBOOK
   ============================================================ */
.guestbook-form { margin-bottom:2rem; }
.guestbook-entries { display:flex; flex-direction:column; gap:1.5rem; margin-top:1.5rem; }
.guestbook-entry { border-left:2px solid var(--accent-green); padding-left:1rem; }
.guestbook-meta { display:flex; align-items:baseline; gap:1rem; margin-bottom:0.25rem; flex-wrap:wrap; }
.guestbook-name { color:var(--accent-green); }
.guestbook-date { font-size:var(--font-size-sm); color:var(--text-muted); font-family:var(--font-mono); }
.guestbook-message { color:var(--text-secondary); }

/* ============================================================
   LINKS
   ============================================================ */
.links-section { margin-bottom:3rem; }
.links-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1rem; margin-top:1rem; }
.link-card {
    display:flex; align-items:center; gap:0.75rem;
    background:var(--bg-card); border:1px solid var(--border-color); border-radius:var(--radius);
    padding:1rem; text-decoration:none; color:var(--text-primary); transition:all var(--transition);
}
.link-card:hover { border-color:var(--accent-green); background:var(--bg-card-hover); transform:translateY(-1px); }
.link-icon { font-size:1.5rem; flex-shrink:0; }
.link-title { font-weight:600; font-size:var(--font-size-sm); }
.link-desc { font-size:0.75rem; color:var(--text-muted); margin-top:0.1rem; }

/* ============================================================
   HOME PAGE
   ============================================================ */
.hero { margin-bottom:3rem; }
.section { margin-bottom:3rem; }
.section-title { font-size:var(--font-size-2xl); margin-bottom:1.5rem; color:var(--text-primary); }
.section-footer { margin-top:1.5rem; }
.quick-links { display:flex; flex-wrap:wrap; gap:0.75rem; }
.quick-link {
    display:inline-flex; align-items:center; gap:0.4rem;
    padding:0.5rem 1rem; border:1px solid var(--border-color); border-radius:9999px;
    text-decoration:none; color:var(--text-secondary); font-size:var(--font-size-sm);
    transition:all var(--transition);
}
.quick-link:hover { border-color:var(--accent-green); color:var(--accent-green); }

/* ============================================================
   CATEGORY FILTER
   ============================================================ */
.category-filter { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:2rem; }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination { display:flex; align-items:center; gap:1rem; margin-top:2rem; justify-content:center; }
.pagination-info { color:var(--text-muted); font-size:var(--font-size-sm); font-family:var(--font-mono); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    background:var(--bg-secondary);
    border-top:1px solid var(--border-color);
    padding:2rem 0;
    margin-top:auto;
    font-size:var(--font-size-sm);
    color:var(--text-muted);
}
.footer-content { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-links { display:flex; gap:1rem; list-style:none; }
.footer-links a { color:var(--text-muted); text-decoration:none; }
.footer-links a:hover { color:var(--accent-green); }

/* ============================================================
   MISC
   ============================================================ */
.breadcrumb { margin-bottom:1.5rem; }
.breadcrumb a { color:var(--accent-green); text-decoration:none; }
.page-intro { color:var(--text-secondary); margin-bottom:1.5rem; font-size:var(--font-size-lg); }
.page-meta { color:var(--text-muted); font-family:var(--font-mono); font-size:var(--font-size-sm); margin-bottom:1.5rem; }
.empty-state { color:var(--text-muted); text-align:center; padding:3rem; }
.ascii-divider { font-family:var(--font-mono); color:var(--text-muted); text-align:center; font-size:0.75rem; margin:2rem 0; }

a { color:var(--accent-green); }
a:hover { color:var(--accent-green-dim); }
h1,h2,h3,h4,h5,h6 { line-height:1.3; color:var(--text-primary); }
