/* ========================================
   TM ARCHIVE - BASE STYLES
   Minimal, customizable, responsive
   ======================================== */

/* --- CSS VARIABLES --- */
:root {
  /* Colors - customize these */
  --color-bg: #fff;
  --color-text: #111;
  --color-text-muted: #666;
  --color-link: #111;
  --color-link-hover: #c00;
  --color-border: #ddd;
  --color-bg-alt: #f5f5f5;
  
  /* Position colors */
  --color-pro: #d4edda;
  --color-pro-text: #155724;
  --color-contra: #f8d7da;
  --color-contra-text: #721c24;
  --color-neutral: #e2e3e5;
  --color-neutral-text: #383d41;
  
  /* Typography - customize these */
  --font-main: system-ui, sans-serif;
  --font-reading: Georgia, serif;
  --font-size-base: 16px;
  --line-height: 1.6;
  
  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 2rem;
  --space-xl: 3rem;
  
  /* Layout */
  --max-width: 1100px;
  --max-width-reading: 700px;
}

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

/* --- BASE --- */
html { font-size: var(--font-size-base); }

body {
  font-family: var(--font-main);
  line-height: var(--line-height);
  color: var(--color-text);
  background: var(--color-bg);
}

a { color: var(--color-link); text-decoration: none; }
a:hover { color: var(--color-link-hover); }

img { max-width: 100%; height: auto; display: block; }

/* --- LAYOUT --- */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-md);
}

/* --- HEADER --- */
.site-header {
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-border);
}

.site-header .container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
}

.site-logo {
  font-weight: bold;
  font-size: 1.25rem;
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

/* --- MAIN --- */
.site-main {
  padding: var(--space-lg) 0;
  min-height: 70vh;
}

/* --- FOOTER --- */
.site-footer {
  padding: var(--space-lg) 0;
  border-top: 1px solid var(--color-border);
  color: var(--color-text-muted);
}

/* --- HERO --- */
.hero {
  padding: var(--space-xl) 0;
  text-align: center;
}

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

/* --- POSITIONS --- */
.position {
  display: inline-block;
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
}

.position--pro { background: var(--color-pro); color: var(--color-pro-text); }
.position--contra { background: var(--color-contra); color: var(--color-contra-text); }
.position--neutral { background: var(--color-neutral); color: var(--color-neutral-text); }

/* --- ARTICLE GRID --- */
.articles-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-lg);
}

.articles-column {
  flex: 1 1 300px;
}

.articles-column__header {
  padding: var(--space-sm);
  margin-bottom: var(--space-md);
  font-size: 0.875rem;
  text-transform: uppercase;
}

/* --- ARTICLE CARD --- */
.article-card {
  display: block;
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.article-card:hover {
  border-color: var(--color-link-hover);
  color: var(--color-text);
}

.article-card__year { font-size: 0.875rem; color: var(--color-text-muted); }
.article-card__title { margin: var(--space-xs) 0; }
.article-card__author { font-size: 0.875rem; color: var(--color-text-muted); }

/* --- ARTICLE DETAIL --- */
.article {
  max-width: var(--max-width-reading);
}

.article__header { margin-bottom: var(--space-lg); }
.article__title { margin: var(--space-sm) 0; }
.article__author { color: var(--color-text-muted); }
.article__meta { font-size: 0.875rem; color: var(--color-text-muted); }

.article__thesis {
  padding: var(--space-md);
  margin: var(--space-lg) 0;
  border-left: 3px solid var(--color-border);
  font-style: italic;
}

.article__content {
  margin: var(--space-lg) 0;
}

.article__text {
  white-space: pre-wrap;
}

/* --- READING MODE --- */
.reading-mode .article__text {
  font-family: var(--font-reading);
  font-size: 1.125rem;
  line-height: 1.8;
}

.reading-toggle {
  margin-bottom: var(--space-md);
}

/* --- LANGUAGE TOGGLE --- */
.lang-toggle {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.lang-toggle__btn {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-border);
  background: none;
  cursor: pointer;
}

.lang-toggle__btn.active {
  background: var(--color-text);
  color: var(--color-bg);
  border-color: var(--color-text);
}

.text-de, .text-en { display: none; }
.lang-de .text-de { display: block; }
.lang-en .text-en { display: block; }

/* --- PAGES/IMAGES --- */
.pages-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.page-thumb {
  flex: 0 0 150px;
  border: 1px solid var(--color-border);
}

.page-thumb img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

/* --- FORMS --- */
.form-group {
  margin-bottom: var(--space-md);
}

.form-group label {
  display: block;
  margin-bottom: var(--space-xs);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: var(--space-sm);
  border: 1px solid var(--color-border);
  font: inherit;
}

.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.form-row > * { flex: 1 1 200px; }

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

/* --- BUTTONS --- */
.btn {
  display: inline-block;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-text);
  background: var(--color-text);
  color: var(--color-bg);
  cursor: pointer;
  font: inherit;
}

.btn:hover { opacity: 0.8; color: var(--color-bg); }
.btn--outline { background: transparent; color: var(--color-text); }
.btn--danger { background: #c00; border-color: #c00; }
.btn--small { padding: var(--space-xs) var(--space-sm); font-size: 0.875rem; }

/* --- ALERTS --- */
.alert {
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  border: 1px solid var(--color-border);
}

.alert--success { background: var(--color-pro); border-color: var(--color-pro-text); }
.alert--error { background: var(--color-contra); border-color: var(--color-contra-text); }

/* --- TABLES --- */
table { width: 100%; border-collapse: collapse; }
th, td { padding: var(--space-sm); text-align: left; border-bottom: 1px solid var(--color-border); }

/* --- STATS --- */
.stats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.stat {
  flex: 1 1 120px;
  padding: var(--space-md);
  text-align: center;
  border: 1px solid var(--color-border);
}

.stat__number { display: block; font-size: 2rem; font-weight: bold; }
.stat__label { font-size: 0.875rem; color: var(--color-text-muted); }

/* --- SECTION --- */
.section { margin-bottom: var(--space-xl); }
.section__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

/* --- UTILITIES --- */
.text-muted { color: var(--color-text-muted); }
.text-center { text-align: center; }
.mt-lg { margin-top: var(--space-lg); }
.mb-lg { margin-bottom: var(--space-lg); }

/* --- UPLOAD --- */
.upload-form {
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  border: 1px dashed var(--color-border);
}

.page-item {
  position: relative;
}

.page-item__delete {
  position: absolute;
  top: var(--space-xs);
  right: var(--space-xs);
}

/* --- AUTH --- */
.auth-box {
  max-width: 400px;
  margin: var(--space-xl) auto;
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
}

.debug-box {
  margin-top: var(--space-md);
  padding: var(--space-md);
  background: #fff3cd;
  word-break: break-all;
}

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 600px) {
  :root {
    --font-size-base: 15px;
  }
  
  .articles-column { flex: 1 1 100%; }
  .stats .stat { flex: 1 1 45%; }
}
