:root {
  --max-content-width: 1200px;
  --sidebar-width: 280px;
  --header-height: 60px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;

  --bg-body: #1a1a1a;
  --bg-main: #2c3e50;
  --bg-sidebar: #2c3e50;
  --bg-header: #2c3e50;
  --bg-topic-card: rgba(52, 73, 94, 0.6);
  --bg-code: #f8f9fa;
  --bg-code-inline: #f8f9fa;
  
  --text-primary: #ecf0f1;
  --text-secondary: #bdc3c7;
  --text-muted: #95a5a6;
  --text-very-muted: #7f8c8d;
  --text-header: white;
  --text-article-title: #bdc3c7;
  
  --accent-primary: #3498db;
  --accent-hover: #3498db;
  --accent-hover-bg: rgba(52, 152, 219, 0.1);
  
  --border-primary: rgba(255, 255, 255, 0.1);
  --border-secondary: #ecf0f1;
  --border-topic-card: #3498db;
  --border-code: #e9ecef;
  
  --shadow-sidebar: rgba(0, 0, 0, 0.3);
  --shadow-main: rgba(0, 0, 0, 0.3);
  --shadow-header: rgba(0, 0, 0, 0.1);

  --article-link-padding: 8px;
  --article-link-radius: 4px;
  --article-link-slide: 4px;
  --transition-speed: 0.2s;
}

body.light-mode {
  --bg-body: #f5f5f5;
  --bg-main: white;
  --bg-sidebar: white;
  --bg-header: #2c3e50;
  --bg-topic-card: #f8f9fa;
  --bg-code: #f8f9fa;
  --bg-code-inline: #f8f9fa;
  
  --text-primary: #333;
  --text-secondary: #555;
  --text-muted: #95a5a6;
  --text-very-muted: #95a5a6;
  --text-header: white;
  --text-article-title: #555;
  
  --accent-primary: #3498db;
  --accent-hover: #3498db;
  --accent-hover-bg: rgba(52, 152, 219, 0.1);
  
  --border-primary: #ecf0f1;
  --border-secondary: #ecf0f1;
  --border-topic-card: #3498db;
  --border-code: #e9ecef;
  
  --shadow-sidebar: rgba(0, 0, 0, 0.05);
  --shadow-main: rgba(0, 0, 0, 0.1);
  --shadow-header: rgba(0, 0, 0, 0.1);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
  line-height: 1.6;
  color: var(--text-primary);
  background-color: var(--bg-body);
  transition: background-color 0.3s ease, color 0.3s ease;
}

header {
  background: var(--bg-header);
  color: var(--text-header);
  height: var(--header-height);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: 0 2px 4px var(--shadow-header);

  .header-content {
    max-width: var(--max-content-width);
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  h1 {
    font-size: 1.5rem;
    font-weight: 600;

    a {
      color: var(--text-header);
      text-decoration: none;
      transition: opacity var(--transition-speed);

      &:hover {
        opacity: 0.8;
      }
    }
  }
}

#theme-toggle {
  background: none;
  border: 2px solid rgba(255, 255, 255, 0.3);
  color: var(--text-header);
  padding: var(--article-link-padding) 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 1rem;
  transition: all var(--transition-speed);
  display: flex;
  align-items: center;
  gap: 6px;

  &:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.5);
  }

  .theme-icon {
    font-size: 1.2rem;
  }
}

.container {
  margin-top: var(--header-height);
  max-width: var(--max-content-width);
  margin-left: auto;
  margin-right: auto;
  display: flex;
  min-height: calc(100vh - var(--header-height));
}

aside {
  width: var(--sidebar-width);
  background: var(--bg-sidebar);
  padding: var(--spacing-lg);
  box-shadow: 2px 0 4px var(--shadow-sidebar);
  overflow-y: auto;
  position: sticky;
  top: var(--header-height);
  height: calc(100vh - var(--header-height));
  transition: background-color 0.3s ease;

  h2 {
    font-size: 1.1rem;
    margin-bottom: var(--spacing-lg);
    color: var(--text-primary);
    padding-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--border-primary);

    a {
      color: var(--text-primary);
      text-decoration: none;
      transition: color var(--transition-speed);

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

  .topic {
    margin-bottom: var(--spacing-lg);

    h3 {
      font-size: 1rem;
      margin-bottom: var(--spacing-sm);
      color: var(--text-primary);
      cursor: pointer;
      transition: color var(--transition-speed);

      a {
        color: inherit;
        text-decoration: none;

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

  .section {
    margin-bottom: var(--spacing-md);

    .section-name {
      font-size: 0.75rem;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.5px;
      color: var(--text-very-muted);
      padding-bottom: 4px;
      margin-bottom: var(--spacing-sm);
      cursor: default;
    }
  }

  ul {
    list-style: none;

    li {
      margin-bottom: 12px;
    }
  }
}

main {
  flex: 1;
  padding: var(--spacing-lg);
  background: var(--bg-main);
  margin: var(--spacing-lg);
  border-radius: var(--article-link-radius) * 2;
  box-shadow: 0 1px 3px var(--shadow-main);
  transition: background-color 0.3s ease;
}

main:has(.home) {
  background: var(--bg-header);
}

article {
  max-width: 800px;

  h1 {
    font-size: 2.5rem;
    margin-bottom: var(--spacing-lg);
    color: var(--text-primary);
    line-height: 1.2;
  }

  h2 {
    font-size: 1.8rem;
    margin-top: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    color: var(--text-primary);
  }

  h3 {
    font-size: 1.3rem;
    margin-top: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    color: var(--text-primary);
  }

  p {
    margin-bottom: var(--spacing-md);
    color: var(--text-secondary);
  }

  ul, ol {
    margin-bottom: var(--spacing-md);
    margin-left: var(--spacing-lg);

    li {
      margin-bottom: 6px;
      color: var(--text-secondary);
    }
  }

  pre {
    background: var(--bg-code);
    padding: var(--spacing-md);
    border-radius: var(--article-link-radius);
    overflow-x: auto;
    margin-bottom: var(--spacing-md);
    border: 1px solid var(--border-code);
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.9rem;
    line-height: 1.4;
  }

  code {
    background: var(--bg-code-inline);
    padding: 2px 6px;
    border-radius: 3px;
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.9em;
  }

  pre code {
    background: none;
    padding: 0;
  }
}

aside ul li a,
.home .topic-card .articles li a,
.topic-index .section ul li a {
  color: var(--text-muted);
  text-decoration: none;
  display: block;
  transition: all calc(var(--transition-speed) * 1) ease;
  padding: var(--article-link-padding);
  margin: calc(var(--article-link-padding) * -1);
  border-radius: var(--article-link-radius);
}

aside ul li a:hover,
.home .topic-card .articles li a:hover,
.topic-index .section ul li a:hover {
  color: var(--accent-hover);
  background: var(--accent-hover-bg);
  transform: translateX(var(--article-link-slide));
}

aside ul li a:hover .article-title,
.home .topic-card .articles li a:hover .article-title,
.topic-index .section ul li a:hover .article-title {
  color: var(--accent-hover);
}

aside ul li a:hover .article-description,
.home .topic-card .articles li a:hover .article-description {
  color: var(--text-muted);
}

aside ul li a .article-title,
.home .topic-card .articles li a .article-title,
.topic-index .section ul li a .article-title {
  color: var(--text-article-title);
  transition: color var(--transition-speed);
}

aside ul li a .article-description,
.home .topic-card .articles li a .article-description,
.topic-index .section ul li a .article-description {
  color: var(--text-very-muted);
  margin-top: 2px;
  line-height: 1.3;
  transition: color var(--transition-speed);
}

aside ul li a .article-title {
  font-size: 0.9rem;
}

aside ul li a .article-description {
  font-size: 0.8rem;
}

.home {
  h1 {
    font-size: 2.5rem;
    margin-bottom: var(--spacing-lg);
    color: var(--text-primary);
  }

  .intro {
    font-size: 1.1rem;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 2px solid var(--border-primary);
  }

  .topics {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
  }

  @media (max-width: 768px) {
    .topics {
      grid-template-columns: 1fr;
    }
  }

  .topic-card {
    background: var(--bg-topic-card);
    padding: var(--spacing-lg);
    border-radius: var(--article-link-radius) * 2;
    border-left: 4px solid var(--border-topic-card);
    transition: background-color 0.3s ease;

    h2 {
      font-size: 1.5rem;
      margin-bottom: var(--spacing-sm);

      a {
        color: var(--text-primary);
        text-decoration: none;
        transition: color var(--transition-speed);

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

    > p {
      color: var(--text-secondary);
      margin-bottom: var(--spacing-md);
    }

    .section {
      strong {
        display: block;
        font-size: 0.95rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.8px;
        color: var(--text-secondary);
        cursor: default;
        padding-bottom: var(--article-link-padding);
        margin-bottom: 12px;
        border-bottom: 2px solid var(--border-primary);
      }
    }

    .articles {
      list-style: none;

      li {
        margin-bottom: 12px;
      }
    }
  }
}

.home .topic-card .articles li a .article-title {
  color: var(--text-primary);
}

.home .topic-card .articles li a .article-description {
  font-size: 0.9rem;
  padding-left: var(--spacing-md);
  line-height: 1.4;
}

.topic-index {
  h1 {
    font-size: 2.5rem;
    margin-bottom: var(--spacing-md);
    color: var(--text-primary);
  }

  .description {
    font-size: 1.1rem;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-lg);
    border-bottom: 2px solid var(--border-secondary);
  }

  .section {
    margin-bottom: var(--spacing-lg);

    h2 {
      font-size: 1.3rem;
      color: var(--text-secondary);
      margin-bottom: var(--spacing-md);
      padding-bottom: var(--spacing-sm);
      border-bottom: 1px solid var(--border-secondary);
    }

    ul {
      list-style: none;

      li {
        margin-bottom: var(--spacing-md);
      }
    }
  }
}

.topic-index .section ul li a {
  color: var(--text-secondary);
}

.topic-index .section ul li a:hover .article-description {
  color: var(--text-secondary);
}

.topic-index .section ul li a .article-title {
  font-size: 1.05rem;
}

.topic-index .section ul li a .article-description {
  font-size: 0.95rem;
  color: var(--text-muted);
  margin-top: 4px;
  line-height: 1.4;
}
