@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800;900&display=swap');

/* GC50plus Theme (abgeleitet aus Screenshot) */
:root{
  --gc-bg:#555555; --gc-panel:rgba(220,224,227,.08); --gc-panel2:rgba(220,224,227,.14);
  --gc-text:#ffffff; --gc-muted:#dce0e3; --gc-border:rgba(220,224,227,.28);
  --gc-line:rgba(220,224,227,.55); --gc-red:#c40000; --gc-sidebar:#949698;
  --gc-radius:14px; --gc-shadow:0 10px 30px rgba(0,0,0,.25);
  --gc-input-bg:rgba(0,0,0,.18); --gc-input-border:rgba(255,255,255,.22);
  --gc-sidebar-link:#ffffff; --gc-sidebar-link-hover:#000000;
  --gc-userbox-bg:rgba(43,44,54,.12); --gc-userbox-border:rgba(43,44,54,.12); --gc-userbox-text:#20212a;
}
body.theme-gc50-dark{
  --gc-bg:#555555; --gc-panel:rgba(220,224,227,.08); --gc-panel2:rgba(220,224,227,.14);
  --gc-text:#ffffff; --gc-muted:#dce0e3; --gc-border:rgba(220,224,227,.28);
  --gc-line:rgba(220,224,227,.55); --gc-red:#c40000; --gc-sidebar:#949698;
  --gc-input-bg:rgba(0,0,0,.18); --gc-input-border:rgba(255,255,255,.22);
  --gc-sidebar-link:#ffffff; --gc-sidebar-link-hover:#000000;
  --gc-userbox-bg:rgba(43,44,54,.12); --gc-userbox-border:rgba(43,44,54,.12); --gc-userbox-text:#20212a;
}
body.theme-gc50-neutral{
  --gc-bg:#676a70; --gc-panel:rgba(255,255,255,.08); --gc-panel2:rgba(255,255,255,.14);
  --gc-text:#ffffff; --gc-muted:#edf0f2; --gc-border:rgba(255,255,255,.22);
  --gc-line:rgba(255,255,255,.35); --gc-red:#c40000; --gc-sidebar:#bcc1c7;
  --gc-input-bg:rgba(27,30,37,.20); --gc-input-border:rgba(255,255,255,.20);
  --gc-sidebar-link:#ffffff; --gc-sidebar-link-hover:#1c1d24;
  --gc-userbox-bg:rgba(255,255,255,.26); --gc-userbox-border:rgba(45,47,56,.10); --gc-userbox-text:#20212a;
}
body.theme-gc50-light{
  --gc-bg:#eef1f4; --gc-panel:rgba(255,255,255,.92); --gc-panel2:rgba(255,255,255,.98);
  --gc-text:#27303a; --gc-muted:#51606e; --gc-border:rgba(88,99,112,.18);
  --gc-line:rgba(88,99,112,.22); --gc-red:#c40000; --gc-sidebar:#d8dde2;
  --gc-input-bg:#ffffff; --gc-input-border:rgba(88,99,112,.22);
  --gc-sidebar-link:#27303a; --gc-sidebar-link-hover:#000000;
  --gc-userbox-bg:rgba(255,255,255,.86); --gc-userbox-border:rgba(88,99,112,.16); --gc-userbox-text:#27303a;
  --gc-shadow:0 12px 30px rgba(59,72,85,.10);
}
body.theme-retro-paket{
  --gc-bg:#efe9df; --gc-panel:rgba(255,252,246,.92); --gc-panel2:rgba(255,252,246,.98);
  --gc-text:#4e443f; --gc-muted:#786b64; --gc-border:rgba(89,78,71,.26);
  --gc-line:rgba(89,78,71,.28); --gc-red:#c85b3e; --gc-sidebar:#625952;
  --gc-input-bg:#fffdfa; --gc-input-border:rgba(89,78,71,.26);
  --gc-sidebar-link:#fff6ee; --gc-sidebar-link-hover:#ffd0b5;
  --gc-userbox-bg:rgba(255,252,246,.18); --gc-userbox-border:rgba(255,255,255,.10); --gc-userbox-text:#fff6ee;
  --gc-shadow:0 12px 28px rgba(78,68,63,.10);
}
body.theme-stadtjaeger{
  --gc-bg:#1c2244; --gc-panel:rgba(40,47,91,.92); --gc-panel2:rgba(30,37,76,.98);
  --gc-text:#ffffff; --gc-muted:#d9dfea; --gc-border:rgba(153,169,210,.18);
  --gc-line:rgba(153,169,210,.20); --gc-red:#ff6a68; --gc-sidebar:#171d3b;
  --gc-input-bg:rgba(11,14,30,.24); --gc-input-border:rgba(153,169,210,.22);
  --gc-sidebar-link:#ffffff; --gc-sidebar-link-hover:#7fc7ea;
  --gc-userbox-bg:rgba(255,255,255,.08); --gc-userbox-border:rgba(153,169,210,.10); --gc-userbox-text:#ffffff;
}
html,body{height:100%} body{margin:0;background:var(--gc-bg);color:var(--gc-text);
  font-family:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;}
.gc-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.gc-sidebar{background:var(--gc-sidebar);padding:18px 16px;box-shadow:inset -1px 0 0 rgba(0,0,0,.10)}
.gc-nav-toggle{
  display:none;
  border:1px solid rgba(43,44,54,.28);
  background:rgba(78,86,99,.10);
  color:#2b2c36;
  font-weight:800;
  border-radius:10px;
  padding:8px 12px;
  cursor:pointer;
}
.gc-mobile-topbar{display:none}
.gc-mobile-logo{
  display:inline-block;
  text-decoration:none;
  color:#fff;
  background:var(--gc-red);
  border-radius:10px;
  padding:8px 12px;
  font-weight:900;
}
.gc-mobile-logo img{
  display:block;
  width:116px;
  max-width:100%;
  height:auto;
}
.gc-sidebar .logo{background:var(--gc-red);color:#fff;padding:18px 16px;margin:-18px -16px 18px;
  font-weight:900;font-size:34px;text-shadow:0 2px 0 rgba(0,0,0,.25);display:block;text-decoration:none}
.gc-sidebar .logo img{
  display:block;
  width:220px;
  max-width:100%;
  height:auto;
  margin:0 auto;
}
.gc-sidebar a{display:block;color:var(--gc-sidebar-link);text-decoration:none;padding:10px;border-radius:10px;font-weight:700;letter-spacing:.01em;text-shadow:0 2px 10px rgba(0,0,0,.22)}
.gc-sidebar a:hover{background:rgba(0,0,0,.08);color:var(--gc-sidebar-link-hover);text-shadow:none}
.gc-sidebar a.sub{margin-left:14px;font-weight:700;font-size:.93rem;padding:8px 10px}
.gc-sidebar a.active{
  background:var(--gc-red);
  border:1px solid rgba(255,255,255,.55);
  color:#fff;
  font-weight:900;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.gc-sidebar .gc-muted{
  color:rgba(43,44,54,.88);
}
.gc-sidebar .gc-userbox,
.gc-sidebar .gc-user-panel{
  background:var(--gc-userbox-bg);
  border:1px solid var(--gc-userbox-border);
  color:var(--gc-userbox-text);
  border-radius:12px;
}
.gc-sidebar .gc-userbox .gc-muted,
.gc-sidebar .gc-user-panel .gc-muted{
  color:rgba(32,33,42,.76);
}
.gc-main{padding:26px 20px} .gc-container{max-width:1200px;margin:0 auto}
h1,h2{margin:0 0 10px;font-family:"Comic Sans MS","Trebuchet MS","Segoe Print","Bradley Hand",cursive;
  font-weight:900;text-shadow:0 2px 0 rgba(0,0,0,.35)}
h1{font-size:54px} h2{font-size:34px}
@media(max-width:900px){h1{font-size:38px}h2{font-size:26px}}
.gc-hr{height:1px;background:var(--gc-line);border:0;margin:18px 0}
.gc-card{background:var(--gc-panel);border:1px solid var(--gc-border);border-radius:var(--gc-radius);
  box-shadow:var(--gc-shadow);padding:16px}
.gc-card.soft{background:var(--gc-panel2)} .gc-muted{color:var(--gc-muted)}
.gc-top{display:flex;gap:10px;align-items:center;flex-wrap:wrap} .gc-spacer{flex:1}
.gc-btn{display:inline-block;border:1px solid rgba(255,255,255,.20);background:rgba(255,255,255,.10);color:#fff;
  padding:.62rem .95rem;border-radius:12px;text-decoration:none;cursor:pointer;font-weight:700;letter-spacing:.01em}
.gc-btn:hover{background:rgba(255,255,255,.16)} .gc-btn.primary{background:var(--gc-red);border-color:rgba(0,0,0,.15)}
.gc-btn.danger{background:#8f1e1e}
label{display:block;margin:.7rem 0 .25rem;color:var(--gc-muted)}
input,select,textarea{width:100%;box-sizing:border-box;padding:.62rem .75rem;border-radius:12px;
  border:1px solid var(--gc-input-border);background:var(--gc-input-bg);color:var(--gc-text);outline:none;
  font:inherit;font-size:1.05rem;line-height:1.25;min-height:44px}
input:focus,select:focus,textarea:focus{border-color:rgba(255,255,255,.45);box-shadow:0 0 0 3px rgba(197,45,45,.25)}
input[type="checkbox"]{
  width:20px;
  min-height:20px;
  height:20px;
  padding:0;
  margin-right:8px;
  vertical-align:middle;
  accent-color:#1f7aec;
}
table{width:100%;border-collapse:collapse;margin-top:14px;background:rgba(0,0,0,.10);border:1px solid rgba(255,255,255,.18);
  border-radius:12px;overflow:hidden}
th,td{padding:11px 10px;border-bottom:1px solid rgba(255,255,255,.12);text-align:left;vertical-align:top}
th{background:rgba(255,255,255,.08);color:rgba(255,255,255,.85);font-weight:800}
tr:hover td{background:rgba(255,255,255,.05)}
.gc-redbar{background:var(--gc-red);padding:10px 14px;border-radius:10px;font-weight:700;
  text-shadow:0 1px 0 rgba(0,0,0,.25);box-shadow:0 10px 30px rgba(0,0,0,.20)}
.gc-kpi{font-size:34px;font-weight:700;margin-top:4px}
.gc-grid{display:grid;gap:12px} .gc-grid.kpi{grid-template-columns:repeat(5,minmax(0,1fr))}
@media(max-width:1200px){.gc-grid.kpi{grid-template-columns:repeat(2,minmax(0,1fr))}}
.gc-grid.bday{grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:1200px){.gc-grid.bday{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.gc-grid.bday{grid-template-columns:1fr}}
.gc-link{color:rgba(255,255,255,.92);text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.35)}
.gc-link:hover{border-bottom-color:rgba(255,255,255,.8)}
.gc-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 9px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:inherit;
  font-size:.92rem;
  font-weight:800;
  line-height:1.2;
}
.gc-chip{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;
  font-weight:900;margin-right:8px;border:1px solid rgba(255,255,255,.2)}
.gc-chip.paid{background:#29c46b} .gc-chip.unpaid{background:#e25555}
.gc-tone-success{
  border-color:rgba(54,220,134,.30) !important;
  background:rgba(54,220,134,.08) !important;
  color:#2d6b47 !important;
}
.gc-tone-error{
  border-color:rgba(240,106,106,.35) !important;
  background:rgba(240,106,106,.10) !important;
  color:#7a342f !important;
}
.gc-tone-info{
  border-color:rgba(79,156,247,.35) !important;
  background:rgba(79,156,247,.08) !important;
  color:#2f4f75 !important;
}
.gc-tone-warn{
  border-color:rgba(243,191,87,.35) !important;
  background:rgba(243,191,87,.10) !important;
  color:#735826 !important;
}
.gc-strong{font-weight:800}
.gc-value-positive{color:#36dc86 !important}
.gc-value-negative{color:#f06a6a !important}
.gc-value-info{color:#4f9cf7 !important}
.gc-value-warn{color:#f3bf57 !important}
.gc-value-zero{color:#6f625a !important}
body.theme-gc50-light th{background:rgba(88,99,112,.08);color:#2c3640}
body.theme-gc50-light table{background:rgba(255,255,255,.95);border-color:rgba(88,99,112,.16)}
body.theme-gc50-light tr:hover td{background:rgba(88,99,112,.05)}
body.theme-gc50-light .gc-btn{border-color:rgba(88,99,112,.16);background:rgba(88,99,112,.06);color:#27303a}
body.theme-gc50-light .gc-btn:hover{background:rgba(88,99,112,.12)}
body.theme-gc50-light .gc-btn.primary,
body.theme-gc50-light .gc-btn.danger{color:#fff}
body.theme-retro-paket th{
  background:#cfc6bc;
  color:#4a403a;
  border-bottom-color:rgba(89,78,71,.38);
  font-weight:900;
}
body.theme-retro-paket th a,
body.theme-retro-paket th .gc-link{
  color:#4a403a;
  border-bottom-color:rgba(89,78,71,.34);
}
body.theme-retro-paket .gc-link{
  color:#4a403a;
  border-bottom-color:rgba(89,78,71,.26);
}
body.theme-retro-paket .gc-link:hover{
  color:#342c28;
  border-bottom-color:rgba(89,78,71,.48);
}
body.theme-retro-paket .gc-muted{
  color:#6f625a;
}
body.theme-retro-paket .gc-pill{
  border-color:rgba(89,78,71,.18);
  background:rgba(89,78,71,.08);
  color:#4a403a;
}
body.theme-retro-paket table{
  background:rgba(255,252,246,.98);
  border-color:rgba(89,78,71,.24);
  box-shadow:inset 0 0 0 1px rgba(89,78,71,.08);
}
body.theme-retro-paket th,
body.theme-retro-paket td{border-bottom-color:rgba(89,78,71,.16)}
body.theme-retro-paket th + th,
body.theme-retro-paket td + td{border-left:1px solid rgba(89,78,71,.12)}
body.theme-retro-paket tr:hover td{background:rgba(89,78,71,.07)}
body.theme-retro-paket .gc-btn{
  border-color:rgba(89,78,71,.28);
  background:rgba(89,78,71,.13);
  color:#433934;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42);
}
body.theme-retro-paket .gc-btn:hover{background:rgba(89,78,71,.19)}
body.theme-retro-paket .gc-btn.primary{
  background:#c85b3e;
  border-color:#a64b33;
}
body.theme-retro-paket .gc-btn.primary:hover{background:#b85036}
body.theme-retro-paket .gc-btn.danger{
  background:#9b2d23;
  border-color:#7c211a;
}
body.theme-retro-paket .gc-btn.primary,
body.theme-retro-paket .gc-btn.danger{color:#fff}

@media(max-width:900px){
  .gc-layout{grid-template-columns:1fr;display:block}
  .gc-mobile-topbar{
    display:flex;
    align-items:center;
    gap:10px;
    position:sticky;
    top:0;
    z-index:1200;
    background:var(--gc-sidebar);
    border-bottom:1px solid rgba(43,44,54,.12);
    padding:10px;
  }
  .gc-sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:min(84vw,290px);
    min-height:100vh;
    overflow:auto;
    z-index:1300;
    padding:12px 10px 14px;
    box-shadow:0 14px 32px rgba(0,0,0,.35);
    transform:translateX(-108%);
    transition:transform .22s ease;
  }
  .gc-sidebar.mobile-open{transform:translateX(0)}
  .gc-sidebar .logo{
    margin:0;
    font-size:22px;
    padding:10px 12px;
    border-radius:10px;
    margin-bottom:12px;
  }
  .gc-nav-toggle{display:inline-block;min-height:40px}
  .gc-sidebar a{
    display:block;
    margin:0 0 8px 0;
    padding:10px 12px;
    font-size:15px;
    line-height:1.2;
    border-radius:10px;
    min-height:42px;
  }
  .gc-sidebar a.sub{margin-left:12px;padding:9px 11px}
  .gc-sidebar hr{margin:10px 0}
  .gc-sidebar.mobile-collapsed .gc-nav-links{display:block}
  .gc-main{padding:14px 10px}
}
