/* Temporan UI — CI #2e2d2c / #52ae32 / #f4f1f1 — Nunito */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700&display=swap');

:root {
  --c-primary:   #2e2d2c;
  --c-accent:    #52ae32;
  --c-accent-dk: #3d8425;
  --c-bg:        #f4f1f1;
  --c-surface:   #ffffff;
  --c-border:    rgba(46,45,44,.12);
  --c-text:      #2e2d2c;
  --c-muted:     rgba(46,45,44,.5);
  --c-danger:    #d94f3d;
  --c-warn:      #e8a020;
  --c-info:      #2b6cb0;
  --radius:      10px;
  --shadow:      0 1px 4px rgba(0,0,0,.08);
}

@media (prefers-color-scheme: dark) {
  :root {
    --c-bg:      #2e2d2c;
    --c-surface: #3d3c3b;
    --c-border:  rgba(244,241,241,.1);
    --c-text:    #f4f1f1;
    --c-muted:   rgba(244,241,241,.45);
  }
}

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

html { font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
  font-family: 'Nunito', sans-serif;
  font-weight: 400;
  background: var(--c-bg);
  color: var(--c-text);
  line-height: 1.6;
  min-height: 100vh;
}

a { color: var(--c-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Layout ── */
.container { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }

.page-wrap {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 100vh;
}

/* ── Topbar ── */
.topbar {
  background: var(--c-primary);
  color: #f4f1f1;
  padding: .75rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.topbar-logo {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.topbar-logo svg { width: 32px; height: 32px; }

.topbar-logo .wordmark {
  font-weight: 300;
  font-size: 1.25rem;
  letter-spacing: .15em;
  color: #f4f1f1;
}

.topbar-logo .powered {
  font-size: .65rem;
  letter-spacing: .1em;
  color: rgba(244,241,241,.4);
  line-height: 1;
}

.topbar-logo .brand {
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .06em;
  color: var(--c-accent);
}

.topbar-nav { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }

.topbar-nav a {
  color: rgba(244,241,241,.75);
  font-size: .875rem;
  padding: .35rem .7rem;
  border-radius: 6px;
  transition: background .15s;
}

.topbar-nav a:hover, .topbar-nav a.active {
  background: rgba(244,241,241,.1);
  color: #f4f1f1;
  text-decoration: none;
}

.topbar-user {
  font-size: .8rem;
  color: rgba(244,241,241,.55);
  display: flex;
  align-items: center;
  gap: .75rem;
}

.topbar-user strong { color: #f4f1f1; }

/* ── Main ── */
.main { padding: 2rem 1.25rem; max-width: 1100px; margin: 0 auto; width: 100%; }

/* ── Cards ── */
.card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow);
}

.card-title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.card-title .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--c-accent);
  flex-shrink: 0;
}

/* ── Grid ── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }

@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ── Stat-Kacheln ── */
.stat {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
}

.stat-label { font-size: .75rem; color: var(--c-muted); letter-spacing: .06em; text-transform: uppercase; }
.stat-value { font-size: 2rem; font-weight: 700; line-height: 1.1; margin: .25rem 0; }
.stat-sub   { font-size: .8rem; color: var(--c-muted); }
.stat.accent .stat-value { color: var(--c-accent); }
.stat.danger .stat-value { color: var(--c-danger); }
.stat.warn   .stat-value { color: var(--c-warn); }

/* ── Stempel-Button ── */
.stamp-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: 100%;
  padding: 1.75rem;
  border: none;
  border-radius: var(--radius);
  font-family: 'Nunito', sans-serif;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
}

.stamp-btn:active { transform: scale(.98); }
.stamp-btn:hover  { opacity: .9; }

.stamp-btn.in  { background: var(--c-accent); color: #fff; }
.stamp-btn.out { background: var(--c-danger);  color: #fff; }
.stamp-btn .stamp-icon { font-size: 2rem; line-height: 1; }
.stamp-btn .stamp-time { font-size: .8rem; font-weight: 400; opacity: .8; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem 1.1rem;
  border: none; border-radius: 7px;
  font-family: 'Nunito', sans-serif;
  font-size: .875rem; font-weight: 600;
  cursor: pointer; transition: opacity .15s;
  text-decoration: none;
}

.btn:hover { opacity: .85; text-decoration: none; }
.btn-primary  { background: var(--c-accent);  color: #fff; }
.btn-dark     { background: var(--c-primary); color: #f4f1f1; }
.btn-outline  { background: transparent; color: var(--c-text); border: 1px solid var(--c-border); }
.btn-danger   { background: var(--c-danger);  color: #fff; }
.btn-sm       { padding: .3rem .75rem; font-size: .8rem; }
.btn-full     { width: 100%; justify-content: center; }

/* ── Formulare ── */
.form-group { margin-bottom: 1rem; }
.form-label {
  display: block; font-size: .85rem; font-weight: 600;
  margin-bottom: .35rem; color: var(--c-text);
}

.form-control {
  width: 100%; padding: .55rem .85rem;
  background: var(--c-bg); color: var(--c-text);
  border: 1px solid var(--c-border); border-radius: 7px;
  font-family: 'Nunito', sans-serif; font-size: .9rem;
  transition: border-color .15s;
}

.form-control:focus {
  outline: none;
  border-color: var(--c-accent);
  box-shadow: 0 0 0 3px rgba(82,174,50,.15);
}

.form-hint { font-size: .75rem; color: var(--c-muted); margin-top: .25rem; }

/* ── Tabellen ── */
.table-wrap { overflow-x: auto; }

table { width: 100%; border-collapse: collapse; font-size: .875rem; }
th {
  text-align: left; padding: .6rem .85rem;
  font-size: .75rem; letter-spacing: .06em; text-transform: uppercase;
  color: var(--c-muted); border-bottom: 1px solid var(--c-border);
}
td { padding: .65rem .85rem; border-bottom: 1px solid var(--c-border); }
tr:last-child td { border-bottom: none; }
tr:hover td { background: rgba(82,174,50,.04); }

/* ── Badges ── */
.badge {
  display: inline-flex; align-items: center;
  padding: .2rem .6rem; border-radius: 20px;
  font-size: .72rem; font-weight: 600; letter-spacing: .04em;
}
.badge-green  { background: rgba(82,174,50,.15);  color: #3d8425; }
.badge-red    { background: rgba(217,79,61,.12);  color: #b33d2d; }
.badge-yellow { background: rgba(232,160,32,.15); color: #9c6c00; }
.badge-gray   { background: rgba(46,45,44,.08);   color: var(--c-muted); }

/* ── Alerts ── */
.alert {
  padding: .85rem 1rem; border-radius: 8px;
  font-size: .875rem; margin-bottom: 1rem;
  display: flex; align-items: flex-start; gap: .6rem;
}
.alert-success { background: rgba(82,174,50,.12);  color: #2e6b1a; border-left: 3px solid var(--c-accent); }
.alert-danger  { background: rgba(217,79,61,.1);   color: #8b2a1f; border-left: 3px solid var(--c-danger); }
.alert-info    { background: rgba(43,108,176,.1);  color: #1a4d80; border-left: 3px solid var(--c-info); }
.alert-warn    { background: rgba(232,160,32,.12); color: #7a5200; border-left: 3px solid var(--c-warn); }

/* ── Login ── */
.login-wrap {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
  background: var(--c-bg); padding: 1rem;
}

.login-box {
  width: 100%; max-width: 400px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 14px; padding: 2.5rem 2rem;
  box-shadow: var(--shadow);
}

.login-logo {
  display: flex; flex-direction: column;
  align-items: center; margin-bottom: 2rem; gap: .3rem;
}

.login-logo svg { width: 56px; height: 56px; }

.login-logo .wordmark {
  font-weight: 300; font-size: 1.5rem;
  letter-spacing: .15em; color: var(--c-text);
}

.login-logo .sub {
  font-size: .65rem; letter-spacing: .25em;
  color: var(--c-accent); text-transform: uppercase;
}

.login-logo .powered-line {
  font-size: .7rem; color: var(--c-muted); letter-spacing: .1em;
}

.login-logo .brand-name {
  font-weight: 600; color: var(--c-accent);
  font-size: .75rem; letter-spacing: .06em;
}

/* ── Mobile Nav Toggle ── */
.nav-toggle {
  display: none;
  background: none; border: none;
  color: #f4f1f1; font-size: 1.4rem;
  cursor: pointer; padding: .25rem .5rem;
}

/* ── Responsive Topbar ── */
@media (max-width: 800px) {
  .topbar-nav { display: none; }
  .nav-toggle { display: block; order: 3; }
  .topbar { flex-wrap: wrap; }
  .topbar-user { order: 2; margin-left: auto; }
  .topbar-nav.open {
    display: flex; flex-direction: column;
    width: 100%; order: 4;
    margin-top: .5rem; gap: .25rem;
  }
  .topbar-nav.open a { padding: .6rem .8rem; }
  .main { padding: 1rem .75rem; }
}

/* ── Dialog / Modal ── */
dialog::backdrop {
  background: rgba(46,45,44,.5);
  backdrop-filter: blur(2px);
}
dialog {
  border: 1px solid var(--c-border) !important;
}
dialog h3 { font-weight: 600; font-size: 1.05rem; }

/* ── Utilities ── */
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.text-muted  { color: var(--c-muted); }
.text-accent { color: var(--c-accent); }
.text-danger { color: var(--c-danger); }
.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-sm     { font-size: .8rem; }
.fw-600      { font-weight: 600; }
.d-flex      { display: flex; }
.align-center{ align-items: center; }
.gap-1       { gap: .5rem; }
.gap-2       { gap: 1rem; }
.flex-1      { flex: 1; }
.w-100       { width: 100%; }
