:root { --bg:#0f1115; --fg:#e8e8ea; --muted:#a7a7ad; --card:#171a21; --line:#2a2f3a; }

* { box-sizing: border-box; }
body { margin:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; background:var(--bg); color:var(--fg); }

.topbar {
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 18px; border-bottom:1px solid var(--line);
  position:sticky; top:0; background:rgba(15,17,21,0.95); backdrop-filter: blur(6px);
}

.brand { display:flex; align-items:center; gap:12px; }
.logo { width:50px; height:50px; object-fit:contain; }
.appname { font-weight:700; letter-spacing:0.2px; }
.subtitle { color:var(--muted); font-size:12px; }

.nav { display:flex; gap:14px; flex-wrap:wrap; }
.nav a { color:var(--fg); text-decoration:none; padding:8px 10px; border-radius:10px; border:1px solid transparent; }
.nav a:hover { border-color:var(--line); background:rgba(255,255,255,0.03); }

.container { padding:18px; max-width:1200px; margin:0 auto; }
h1 { margin: 6px 0 14px; font-size: 26px; }
h2 { margin: 0 0 10px; font-size: 18px; }

.muted { color:var(--muted); }
.alert { padding:12px 14px; border:1px solid #5a2d2d; background:rgba(160,50,50,0.15); border-radius:12px; margin:10px 0; }
.alert.success { border:1px solid #2d5a3a; background:rgba(50,160,90,0.12); }

.grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap:14px; margin-top:14px; }
.card { display:block; padding:14px; border-radius:16px; background:var(--card); border:1px solid var(--line); text-decoration:none; color:var(--fg); }
.card:hover { transform: translateY(-1px); transition: 0.12s ease; }

.panel { padding:14px; border-radius:16px; background:var(--card); border:1px solid var(--line); margin:14px 0; }
.footer { padding:14px 18px; border-top:1px solid var(--line); color:var(--muted); display:flex; gap:10px; justify-content:center; }

.label { display:block; margin:10px 0 6px; color:var(--muted); font-size:13px; }
.input {
  width:100%; padding:10px 12px; border-radius:12px;
  border:1px solid var(--line); background:#0c0f14; color:var(--fg);
}
.btn {
  margin-top:12px; padding:10px 14px; border-radius:12px;
  border:1px solid var(--line); background:rgba(255,255,255,0.06); color:var(--fg);
  cursor:pointer; text-decoration:none; display:inline-block;
}
.btn:hover { background:rgba(255,255,255,0.10); }
.btn.danger { border-color:#5a2d2d; background:rgba(160,50,50,0.12); }

.row { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap:12px; }

.table { width:100%; border-collapse: collapse; }
.table th, .table td { padding:10px; border-bottom:1px solid var(--line); text-align:left; }

/* News Layout */
.news-layout{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap:14px;
  align-items:start;
}
@media (max-width: 980px){
  .news-layout{ grid-template-columns: 1fr; }
}
.news-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-end;
}
.news-controls .inline{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:180px;
}
.news-list{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:8px;
}
.news-item{
  display:flex;
  gap:10px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,0.02);
  cursor:pointer;
}
.news-item:hover{
  background:rgba(255,255,255,0.04);
}
.news-check{ margin-top:4px; }
.news-title{ font-weight:600; line-height:1.25; }
.news-sub{
  margin-top:4px;
  font-size:12px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.textarea{
  min-height: 160px;
  resize: vertical;
}
.btn-row{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
/* Header: Uhr + Datum */
.topbar-right{
  display:flex;
  align-items:flex-end;
  gap:16px;
}

.clock{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  line-height:1.1;
  min-width: 170px;
}

.clock-time{
  font-size:16px;
  font-weight:700;
  letter-spacing:0.5px;
}

.clock-date{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}

/* Login: eigener Layout-Modus */
.container-login{
  max-width: 520px;
  padding-top: 36px;
}

.footer-login{
  opacity: 0.7;
}

.login-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}

.login-logo{
  width: 170px;      /* größer */
  height: 170px;
  object-fit: contain;
  margin-bottom: 6px;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.35));
}

.login-title{
  margin: 0 0 10px;
  font-size: 24px;
}

.login-panel{
  width: 100%;
  text-align:left;
}
.mod-layout{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  align-items:start;
}

@media (max-width: 980px){
  .mod-layout{ grid-template-columns: 1fr; }
}

.mod-raw{ min-height: 280px; }
.mod-spk{ min-height: 280px; }

