/*
  /2026/auth.css
  Modernes, flaches Styling fuer die bestehende auth.php
  Kein Markup-Umbau noetig.
*/

:root {
  --color-primary: #41644c;
  --color-primary-light: #e7ebda;
  --color-secondary: #7aa141;
  --color-secondary-light: #e7ebda;
  --color-accent: #7aa141;
  --color-text: #3c3c3b;
  --color-white: #ffffff;
  --color-gray: #dedede;

  --auth-bg: #f7f8f4;
  --auth-border: var(--color-gray);
  --auth-radius: 18px;
  --auth-shadow: none;
  --auth-focus: rgba(65, 100, 76, 0.22);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  min-height: 100vh;
  padding: 24px;
  background:
    radial-gradient(circle at top left, var(--color-primary-light), transparent 34rem),
    var(--auth-bg);
  color: var(--color-text);
  font-family: Verdana, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
}

center {
  min-height: calc(100vh - 48px);
  display: flex;
  align-items: center;
  justify-content: center;
}

form {
  width: min(100%, 450px);
}

/* Nur die aeusserste Tabelle bekommt den Container-Look */
form > table {
  width: 100% !important;
  max-width: 450px;
  border: 1px solid var(--auth-border);
  border-radius: var(--auth-radius);
  background: var(--color-white);
  box-shadow: var(--auth-shadow);
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
}

/* Innere Tabellen bleiben neutral, damit keine Nested Cards entstehen */
form table table {
  width: 100% !important;
  border: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  border-collapse: collapse;
}

td {
  color: var(--color-text);
  font-family: Verdana, Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: normal;
  vertical-align: top;
}

form > table > tbody > tr:first-child > td {
  padding: 26px 28px 18px;
}

form > table > tbody > tr:last-child > td.grau {
  padding: 14px 20px;
  border-top: 1px solid var(--auth-border);
  background: var(--color-primary-light);
}

td.grau {
  border: 0;
  background: var(--color-primary-light);
  color: var(--color-text);
}

form table table tr:nth-child(2) td.grau {
  padding: 14px 16px;
  border-left: 4px solid var(--color-secondary);
  border-radius: 0;
  background: var(--color-primary-light);
}

span.titel {
  display: block;
  margin: 0 0 12px;
  color: var(--color-primary);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

span.untertitel,
span.untertiteltitel-gelb,
span.einleitung {
  font-weight: 700;
}

span.klein {
  color: var(--color-text);
  font-size: 12px;
}

input[type="text"],
input[type="password"] {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--auth-border);
  border-radius: 10px;
  background: var(--color-white);
  color: var(--color-text);
  font: inherit;
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease;
}

input[type="text"]:focus,
input[type="password"]:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px var(--auth-focus);
}

input[type="submit"] {
  min-height: 42px;
  padding: 10px 18px;
  border: 0;
  border-radius: 999px;
  background: var(--color-primary);
  color: var(--color-white);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 160ms ease, transform 160ms ease;
}

input[type="submit"]:hover,
input[type="submit"]:focus-visible {
  background: var(--color-secondary);
  transform: translateY(-1px);
}

input[type="submit"]:active {
  transform: translateY(0);
}

a:link,
a:visited,
a:active,
a.bold:link,
a.bold:visited,
a.bold:active {
  color: var(--color-primary);
  font-family: Verdana, Helvetica, Arial, sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-decoration-line: underline;
  text-decoration-color: var(--color-secondary);
  text-decoration-thickness: 2px;
  text-underline-offset: 4px;
}

a:hover,
a.bold:hover {
  color: var(--color-secondary);
}

td.padding {
  color: var(--color-text);
  padding-left: 5px;
  margin-left: 0;
}

@media (max-width: 560px) {
  body {
    padding: 14px;
  }

  center {
    min-height: calc(100vh - 28px);
  }

  form > table {
    max-width: none;
    border-radius: 14px;
  }

  form > table > tbody > tr:first-child > td {
    padding: 22px 18px 16px;
  }

  span.titel {
    font-size: 22px;
  }

  td {
    font-size: 13px;
  }

  form table table tr:nth-child(3) td,
  form table table tr:nth-child(4) td {
    display: block;
    width: 100%;
    padding: 4px 0;
  }

  form table table tr:nth-child(3) td:first-child,
  form table table tr:nth-child(4) td:first-child {
    padding-top: 12px;
    font-weight: 700;
  }

  input[type="submit"] {
    width: 100%;
    margin-top: 10px;
  }

  form > table > tbody > tr:last-child > td.grau table td {
    display: block;
    width: 100%;
    text-align: center !important;
    padding: 5px 0;
  }
}
