body,form,figure{margin:0;padding:0}img{border:0}header,footer,nav,section,aside,article,figure,figcaption{display:block}body{font-size:100.01%}select,input,textarea{font-size:99%}#container,.inside{position:relative}#main,#left,#right{float:left;position:relative}#main{width:100%}#left{margin-left:-100%}#right{margin-right:-100%}#footer{clear:both}#main .inside{min-height:1px}.ce_gallery>ul,.content-gallery>ul{margin:0;padding:0;overflow:hidden;list-style:none}.ce_gallery>ul li,.content-gallery>ul li{float:left}.ce_gallery>ul li.col_first,.content-gallery>ul li.col_first{clear:left}.float_left,.media--left>figure{float:left}.float_right,.media--right>figure{float:right}.block{overflow:hidden}.media{display:flow-root}.clear,#clear{height:.1px;font-size:.1px;line-height:.1px;clear:both}.invisible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.custom{display:block}#container:after,.custom:after{content:"";display:table;clear:both}
@media (max-width:767px){#wrapper{margin:0;width:auto}#container{padding-left:0;padding-right:0}#main,#left,#right{float:none;width:auto}#left{right:0;margin-left:0}#right{margin-right:0}}img{max-width:100%;height:auto}.audio_container audio{max-width:100%}.video_container video{max-width:100%;height:auto}.aspect,.responsive{position:relative;height:0}.aspect iframe,.responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%}.aspect--16\:9,.responsive.ratio-169{padding-bottom:56.25%}.aspect--16\:10,.responsive.ratio-1610{padding-bottom:62.5%}.aspect--21\:9,.responsive.ratio-219{padding-bottom:42.8571%}.aspect--4\:3,.responsive.ratio-43{padding-bottom:75%}.aspect--3\:2,.responsive.ratio-32{padding-bottom:66.6666%}
/* =============================================================================
   IRON HORIZON — Military Theme for Contao 5
   Ästhetik: Taktisches Lagezentrum / Militärische Dokumentenoptik
   Schriften: Share Tech Mono (operational), Oswald (headings), Source Serif 4 (body)
   ============================================================================= */

/* --- Google Fonts Import --------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Oswald:wght@400;600&family=Source+Serif+4:ital,wght@0,300;1,300&display=swap');

/* --- CSS Custom Properties (Farbpalette & Tokens) -------------------------- */
:root {
  /* Grundfarben */
  --mil-bg-base:        #1a1c18;   /* Haupthintergrund */
  --mil-bg-deep:        #0f1209;   /* Tiefster Hintergrund, Cards */
  --mil-bg-surface:     #111310;   /* Header, Nav-Hintergrund */
  --mil-bg-void:        #0a0c08;   /* Statusbar, tiefste Widgets */
  --mil-bg-hover:       #1e2818;   /* Hover-Zustand */
  --mil-bg-accent:      #2d3d14;   /* Logo-Block, Akzentflächen */

  /* Rahmen & Trennlinien */
  --mil-border-strong:  #4a5c2a;   /* Hauptrahmen, Header-Trenner */
  --mil-border-mid:     #2a3020;   /* Mittlere Rahmen */
  --mil-border-soft:    #1a1e14;   /* Subtile Trenner */
  --mil-border-amber:   #2a2010;   /* Amber-Akzent-Rahmen */

  /* Textfarben */
  --mil-text-primary:   #c8c9a8;   /* Haupttext */
  --mil-text-secondary: #6a7a5a;   /* Sekundärtext, Metadaten */
  --mil-text-muted:     #4a5a3a;   /* Gedämpft, Timestamps */
  --mil-text-ghost:     #3a4a2a;   /* Fast unsichtbar */

  /* Akzentfarben */
  --mil-green-bright:   #7a9a5a;   /* Aktive Elemente, Namen */
  --mil-green-mid:      #6a8a3a;   /* Unit-Code, Status-Dots aktiv */
  --mil-green-deep:     #5a7a3a;   /* Widget-Titel */
  --mil-green-nav:      #4a6a2a;   /* Nav-Status */
  --mil-amber:          #8a6a2a;   /* Standby, Pinned */
  --mil-amber-text:     #d4c98a;   /* Haupttitel (Amber/Gold) */
  --mil-red:            #7a2a2a;   /* Geschlossen, Fehler */

  /* Typografie */
  --font-mono:    'Share Tech Mono', 'Courier New', monospace;
  --font-display: 'Oswald', 'Impact', sans-serif;
  --font-body:    'Source Serif 4', Georgia, serif;

  /* Abstände */
  --space-xs:  4px;
  --space-sm:  8px;
  --space-md:  12px;
  --space-lg:  16px;
  --space-xl:  24px;

  /* Scanline-Overlay (atmosphärischer Effekt) */
  --scanline: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 3px,
    rgba(0, 0, 0, 0.05) 3px,
    rgba(0, 0, 0, 0.05) 4px
  );
}

/* --- Reset & Basis --------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-mono);
  background-color: var(--mil-bg-base);
  color: var(--mil-text-primary);
  line-height: 1.6;
  min-height: 100vh;
  /* Atmosphärisches Scanline-Overlay über der gesamten Seite */
  background-image: var(--scanline);
}

/* Selektionsfarbe */
::selection {
  background: var(--mil-green-mid);
  color: var(--mil-bg-deep);
}

/* --- Scrollbar ------------------------------------------------------------- */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: var(--mil-bg-deep);
}
::-webkit-scrollbar-thumb {
  background: var(--mil-border-mid);
  border-radius: 0;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--mil-green-deep);
}

/* --- Typografie Grundregeln ------------------------------------------------ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--mil-amber-text);
  line-height: 1.2;
}

h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1rem; }

p {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 0.95rem;
  color: var(--mil-text-primary);
  margin-bottom: var(--space-md);
}

a {
  color: var(--mil-green-bright);
  text-decoration: none;
  transition: color 0.15s ease;
}

a:hover {
  color: var(--mil-amber-text);
}

code, pre, .mono {
  font-family: var(--font-mono);
  font-size: 0.85rem;
}

/* --- Seitenwrapper --------------------------------------------------------- */
#wrapper,
.wrapper,
#container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* --- HEADER --------------------------------------------------------------- */
#header {
  background: var(--mil-bg-surface);
  border-bottom: 1px solid var(--mil-border-strong);
  position: sticky;
  top: 0;
  z-index: 100;
}

.header-inner {
  display: flex;
  align-items: stretch;
  max-width: 1280px;
  margin: 0 auto;
}

/* Logo-Block (linke Akzentfläche) */
.logo-block,
#header .logo {
  background: var(--mil-bg-accent);
  padding: var(--space-md) var(--space-xl);
  border-right: 1px solid var(--mil-border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 90px;
  text-decoration: none;
}

.logo-block .emblem {
  font-size: 2rem;
  line-height: 1;
  filter: sepia(1) saturate(0.3) brightness(1.4);
}

.logo-block .unit-code,
#header .logo small {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--mil-green-mid);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-top: var(--space-xs);
}

/* Site-Titel */
.site-title {
  padding: var(--space-md) var(--space-xl);
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.site-title h1,
#header h1 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--mil-amber-text);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin: 0;
}

.site-title .tagline,
#header .tagline {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  color: var(--mil-text-ghost);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Zulu-Zeit Block */
.zulu-block {
  padding: var(--space-md) var(--space-lg);
  border-left: 1px solid var(--mil-border-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  gap: var(--space-xs);
}

.zulu-time {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--mil-green-mid);
  letter-spacing: 1px;
}

.zulu-date {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  color: var(--mil-text-ghost);
}

/* --- STATUSBAR ------------------------------------------------------------ */
#statusbar,
.statusbar {
  background: var(--mil-bg-void);
  border-bottom: 1px solid var(--mil-border-soft);
  padding: var(--space-xs) var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--mil-green-nav);
}

.statusbar .status-item {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.status-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--mil-green-mid);
  flex-shrink: 0;
  animation: pulse 2.5s ease-in-out infinite;
}

.status-dot.amber { background: var(--mil-amber); }
.status-dot.red   { background: var(--mil-red); }

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}

.statusbar .value {
  color: var(--mil-green-bright);
}

/* --- NAVIGATION ----------------------------------------------------------- */
#nav,
nav,
.navigation {
  background: var(--mil-bg-deep);
  border-bottom: 1px solid var(--mil-border-soft);
}

#nav ul,
nav ul,
.navigation ul {
  list-style: none;
  display: flex;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

#nav ul li a,
nav ul li a,
.navigation ul li a {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--mil-text-muted);
  padding: var(--space-sm) var(--space-md);
  border-right: 1px solid var(--mil-border-soft);
  text-decoration: none;
  transition: color 0.15s, background 0.15s;
  position: relative;
}

#nav ul li a:hover,
nav ul li a:hover,
.navigation ul li a:hover,
#nav ul li.active a,
nav ul li.active a,
.navigation ul li.active a,
#nav ul li.trail a,
nav ul li.trail a {
  color: var(--mil-text-primary);
  background: var(--mil-bg-hover);
}

/* Aktiver Nav-Item — grüner Unterstrich */
#nav ul li.active a::after,
nav ul li.active a::after,
.navigation ul li.active a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--mil-green-mid);
}

/* --- HAUPTLAYOUT ---------------------------------------------------------- */
#main,
.main {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-lg);
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: var(--space-md);
}

/* Ohne Sidebar: volle Breite */
#main.no-sidebar,
.main.no-sidebar {
  grid-template-columns: 1fr;
}

#left,
.content-column {
  min-width: 0; /* verhindert overflow im Grid */
}

#right,
.sidebar-column {
  min-width: 0;
}

/* --- CONTENT BEREICH ------------------------------------------------------ */
#left article,
.content-column article,
.mod_article {
  margin-bottom: var(--space-xl);
}

/* --- FORUM-THREADS (Listenelemente) --------------------------------------- */
.thread,
.forumpost,
.mod_article .thread {
  background: var(--mil-bg-deep);
  border: 1px solid var(--mil-border-mid);
  border-left: 3px solid var(--mil-green-nav);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-sm);
  border-radius: 1px;
  transition: border-color 0.15s, background 0.15s;
  cursor: pointer;
}

.thread:hover,
.forumpost:hover {
  border-color: var(--mil-green-mid);
  background: var(--mil-bg-hover);
}

/* Gepinnter Thread */
.thread.pinned,
.forumpost.pinned {
  border-left-color: var(--mil-amber);
  background: #111008;
}

/* Thread-Header Zeile */
.thread-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-xs);
}

/* Thread-Tag (Kategorie-Label) */
.thread-tag,
.category-tag {
  font-family: var(--font-mono);
  font-size: 0.5rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: var(--mil-border-mid);
  color: var(--mil-green-mid);
  padding: 1px 6px;
  border-radius: 1px;
  white-space: nowrap;
  flex-shrink: 0;
}

.thread-tag.pinned  { background: var(--mil-border-amber); color: var(--mil-amber); }
.thread-tag.intel   { background: #0a1520; color: #4a7aaa; }
.thread-tag.admin   { background: #1a1020; color: #7a5a9a; }
.thread-tag.ops     { background: #0a1a0a; color: var(--mil-green-mid); }

/* Thread-Titel */
.thread-title,
.forumpost h2,
.forumpost h3 {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 400;
  color: var(--mil-text-primary);
  letter-spacing: 0.5px;
  flex: 1;
  margin: 0;
  text-transform: none;
}

/* Timestamp */
.thread-ts,
.post-timestamp {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--mil-text-ghost);
  letter-spacing: 1px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Thread-Meta (Autor, Replies) */
.thread-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-xs);
}

.thread-author {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--mil-text-muted);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.thread-author strong {
  color: var(--mil-green-bright);
  font-weight: 400;
}

.thread-replies {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--mil-text-ghost);
  letter-spacing: 1px;
}

/* --- SIDEBAR WIDGETS ------------------------------------------------------ */
#right .widget,
.sidebar-column .widget,
.mod_sidebar_widget {
  background: var(--mil-bg-void);
  border: 1px solid var(--mil-border-mid);
  border-radius: 1px;
  margin-bottom: var(--space-md);
  overflow: hidden;
}

.widget-header {
  background: var(--mil-bg-deep);
  padding: var(--space-xs) var(--space-md);
  border-bottom: 1px solid var(--mil-border-mid);
}

.widget-title,
#right .widget h2,
#right .widget h3 {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mil-green-deep);
  margin: 0;
  font-weight: 400;
}

.widget-body {
  padding: var(--space-sm) var(--space-md);
}

/* Sidebar-Listen-Items */
.widget-body ul {
  list-style: none;
}

.widget-body ul li {
  padding: var(--space-xs) 0;
  border-bottom: 1px solid var(--mil-border-soft);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-mono);
  font-size: 0.65rem;
  color: var(--mil-text-secondary);
}

.widget-body ul li:last-child {
  border-bottom: none;
}

/* Op-Status-Indikator */
.op-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--mil-green-mid);
  flex-shrink: 0;
}

.op-dot.amber { background: var(--mil-amber); }
.op-dot.red   { background: var(--mil-red); }

.op-status {
  font-family: var(--font-mono);
  font-size: 0.5rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-left: auto;
}

.op-status.active  { color: var(--mil-green-mid); }
.op-status.standby { color: var(--mil-amber); }
.op-status.closed  { color: var(--mil-red); }

/* Widget-Footer (Gitterreferenz) */
.widget-footer,
.widget-gridref {
  font-family: var(--font-mono);
  font-size: 0.5rem;
  color: var(--mil-text-ghost);
  letter-spacing: 1px;
  padding: var(--space-sm) var(--space-md);
  border-top: 1px solid var(--mil-border-soft);
  text-align: center;
}

/* --- ARTIKEL / EINZELBEITRÄGE --------------------------------------------- */
.article-content,
.mod_article .content {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--mil-text-primary);
}

/* Klassifikations-Banner über Artikeln */
.classification-banner {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  text-align: center;
  padding: var(--space-xs) var(--space-md);
  margin-bottom: var(--space-md);
  border: 1px solid var(--mil-border-mid);
  color: var(--mil-amber);
  background: var(--mil-border-amber);
}

/* Horizontale Trennlinie im Artikel-Stil */
hr {
  border: none;
  border-top: 1px solid var(--mil-border-mid);
  margin: var(--space-xl) 0;
  position: relative;
}

hr::after {
  content: '◆';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--mil-bg-base);
  padding: 0 var(--space-sm);
  color: var(--mil-border-mid);
  font-size: 0.5rem;
}

/* Blockquote (Funknachrichten, Berichte) */
blockquote {
  border-left: 2px solid var(--mil-green-nav);
  padding: var(--space-sm) var(--space-md);
  margin: var(--space-md) 0;
  background: var(--mil-bg-deep);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--mil-text-secondary);
  font-style: normal;
}

blockquote::before {
  content: '// TRANSMISSION';
  display: block;
  font-size: 0.5rem;
  letter-spacing: 3px;
  color: var(--mil-green-deep);
  margin-bottom: var(--space-xs);
}

/* --- TABELLEN ------------------------------------------------------------- */
table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  margin-bottom: var(--space-md);
}

thead {
  background: var(--mil-bg-deep);
  border-bottom: 1px solid var(--mil-border-strong);
}

thead th {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--mil-green-deep);
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  font-weight: 400;
}

tbody tr {
  border-bottom: 1px solid var(--mil-border-soft);
  transition: background 0.1s;
}

tbody tr:hover {
  background: var(--mil-bg-deep);
}

tbody td {
  padding: var(--space-sm) var(--space-md);
  color: var(--mil-text-secondary);
}

/* --- FORMULARE ------------------------------------------------------------ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  background: var(--mil-bg-deep);
  color: var(--mil-text-primary);
  border: 1px solid var(--mil-border-mid);
  border-radius: 1px;
  padding: var(--space-sm) var(--space-md);
  width: 100%;
  transition: border-color 0.15s;
  outline: none;
  letter-spacing: 0.5px;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--mil-green-mid);
}

input::placeholder,
textarea::placeholder {
  color: var(--mil-text-ghost);
  letter-spacing: 1px;
  font-size: 0.65rem;
  text-transform: uppercase;
}

label {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--mil-text-muted);
  display: block;
  margin-bottom: var(--space-xs);
}

/* --- BUTTONS -------------------------------------------------------------- */
button,
input[type="submit"],
.btn,
.submit {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  background: transparent;
  color: var(--mil-green-mid);
  border: 1px solid var(--mil-green-nav);
  padding: var(--space-sm) var(--space-xl);
  border-radius: 1px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

button:hover,
input[type="submit"]:hover,
.btn:hover {
  background: var(--mil-green-nav);
  color: var(--mil-bg-deep);
  border-color: var(--mil-green-mid);
}

button:active,
input[type="submit"]:active,
.btn:active {
  transform: scale(0.98);
}

/* Primär-Button */
.btn-primary {
  background: var(--mil-green-nav);
  color: var(--mil-bg-deep);
  border-color: var(--mil-green-mid);
}

/* Danger-Button */
.btn-danger {
  color: var(--mil-red);
  border-color: var(--mil-red);
}

/* --- PAGINIERUNG ----------------------------------------------------------- */
.pagination,
.mod_pagination {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 1px;
  margin: var(--space-xl) 0;
}

.pagination a,
.mod_pagination a {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--mil-border-mid);
  color: var(--mil-text-muted);
  transition: border-color 0.15s, color 0.15s;
}

.pagination a:hover,
.mod_pagination a:hover,
.pagination .active,
.mod_pagination .active {
  border-color: var(--mil-green-mid);
  color: var(--mil-green-bright);
  background: var(--mil-bg-deep);
}

/* --- BREADCRUMB ----------------------------------------------------------- */
.breadcrumb,
.mod_breadcrumb {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--mil-text-ghost);
  padding: var(--space-sm) var(--space-lg);
  border-bottom: 1px solid var(--mil-border-soft);
  background: var(--mil-bg-surface);
}

.breadcrumb a,
.mod_breadcrumb a {
  color: var(--mil-text-muted);
}

.breadcrumb a::after,
.mod_breadcrumb a::after {
  content: ' ›';
  margin: 0 var(--space-xs);
  color: var(--mil-text-ghost);
}

/* --- FLASH-MELDUNGEN ------------------------------------------------------ */
.message,
.tl_confirm,
.tl_error,
.tl_info {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.5px;
  padding: var(--space-sm) var(--space-md);
  border-left: 3px solid;
  margin-bottom: var(--space-md);
  border-radius: 1px;
}

.tl_confirm { border-color: var(--mil-green-mid); background: #0a1a0a; color: var(--mil-green-bright); }
.tl_error   { border-color: var(--mil-red);        background: #1a0a0a; color: #aa5a5a; }
.tl_info    { border-color: var(--mil-amber);       background: #1a1508; color: var(--mil-amber); }

/* --- FOOTER --------------------------------------------------------------- */
#footer {
  background: var(--mil-bg-surface);
  border-top: 1px solid var(--mil-border-mid);
  padding: var(--space-xl) var(--space-lg);
  margin-top: var(--space-xl);
}

#footer .footer-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#footer p,
#footer .copyright {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--mil-text-ghost);
  margin: 0;
}

#footer a {
  color: var(--mil-text-muted);
}

/* Grid-Referenz im Footer */
#footer .grid-ref {
  font-family: var(--font-mono);
  font-size: 0.5rem;
  color: var(--mil-text-ghost);
  letter-spacing: 2px;
}

/* --- UTILITY-KLASSEN ------------------------------------------------------ */

/* Klassifikations-Labels */
.label-fouo    { color: var(--mil-amber); }
.label-secret  { color: #aa4a4a; }
.label-unclass { color: var(--mil-green-mid); }

/* Militärische Zeitformatierung */
.zulu { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 1px; color: var(--mil-text-muted); }

/* Versteckt, aber zugänglich */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

/* --- RESPONSIVE ----------------------------------------------------------- */
@media (max-width: 900px) {
  #main,
  .main {
    grid-template-columns: 1fr;
  }

  #right,
  .sidebar-column {
    order: -1; /* Sidebar oben auf Mobile */
  }

  .site-title h1,
  #header h1 {
    font-size: 1.1rem;
    letter-spacing: 2px;
  }

  .zulu-block {
    display: none; /* Auf kleinen Screens ausblenden */
  }

  #nav ul {
    flex-wrap: wrap;
  }
}

@media (max-width: 600px) {
  #wrapper,
  .wrapper,
  #container,
  #main,
  .main {
    padding: var(--space-sm);
  }

  .logo-block,
  #header .logo {
    min-width: 60px;
    padding: var(--space-sm) var(--space-md);
  }
}

/* --- ZULU-ZEIT JAVASCRIPT-HOOK -------------------------------------------- */
/* Das JS für die laufende Uhr kommt in eine separate .js Datei             */
/* Klassen: .js-zulu-time und .js-zulu-date                                 */

/* --- SEITENSPEZIFISCHE KLASSEN -------------------------------------------- */

/* Startseite Hero-Bereich */
.page-home .hero {
  background: var(--mil-bg-deep);
  border: 1px solid var(--mil-border-mid);
  border-left: 3px solid var(--mil-amber);
  padding: var(--space-xl);
  margin-bottom: var(--space-lg);
}

.page-home .hero h2 {
  font-size: 1rem;
  color: var(--mil-amber-text);
  margin-bottom: var(--space-sm);
}

.page-home .hero p {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--mil-text-secondary);
  letter-spacing: 0.5px;
  margin: 0;
}
