/* Allgemein */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    font-family:Arial, Helvetica, sans-serif;
    background:#f5f5f5;
    color:#333;
}

.container{
    max-width:1200px;
    margin:20px auto;
    padding:20px;
}

/* Header */

.header{
    background:#2e7d32;
    color:#fff;
    padding:15px 20px;
}

.header h1{
    font-size:24px;
}

/* Karten */

.card{
    background:#fff;
    border-radius:10px;
    padding:20px;
    margin-bottom:20px;
    box-shadow:0 2px 10px rgba(0,0,0,.1);
}

/* Formulare */

input,
textarea,
select{
    width:100%;
    padding:12px;
    margin-top:5px;
    margin-bottom:15px;
    border:1px solid #ccc;
    border-radius:5px;
}

button{
    background:#2e7d32;
    color:#fff;
    border:none;
    padding:12px 20px;
    border-radius:5px;
    cursor:pointer;
}

button:hover{
    background:#256428;
}

/* Links */

a{
    color:#2e7d32;
    text-decoration:none;
}

a:hover{
    text-decoration:underline;
}

/* Tabellen */

table{
    width:100%;
    border-collapse:collapse;
}

th{
    background:#2e7d32;
    color:#fff;
}

th,
td{
    padding:12px;
    border:1px solid #ddd;
}

/* Fehlermeldungen */

.error{
    background:#ffe5e5;
    color:#c00;
    padding:10px;
    border-radius:5px;
    margin-bottom:15px;
}

.success{
    background:#e5ffe5;
    color:#008000;
    padding:10px;
    border-radius:5px;
    margin-bottom:15px;
}

/* Smartphone */

@media screen and (max-width:768px){

    .container{
        padding:10px;
    }

    table,
    thead,
    tbody,
    th,
    td,
    tr{
        display:block;
    }

    thead{
        display:none;
    }

    tr{
        background:#fff;
        margin-bottom:15px;
        border-radius:8px;
        padding:10px;
        box-shadow:0 1px 5px rgba(0,0,0,.1);
    }

    td{
        border:none;
        padding:6px 0;
    }

    td:before{
        content:attr(data-label);
        font-weight:bold;
        display:block;
    }

    button{
        width:100%;
    }
}

.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    background:#f4f4f4;
}

.login-card{
    width:100%;
    max-width:420px;
    background:#fff;
    padding:25px;
    border-radius:12px;
    box-shadow:0 4px 15px rgba(0,0,0,.12);
}

.login-card h1,
.login-card h2{
    text-align:center;
    margin-bottom:15px;
}

.login-card label{
    font-weight:bold;
}

.login-card input{
    width:100%;
    font-size:16px;
    padding:14px;
    margin-bottom:15px;
}

.login-card button{
    width:100%;
    font-size:17px;
    padding:14px;
}

.login-links{
    text-align:center;
    margin-top:18px;
}

@media screen and (max-width:600px){

    body{
        background:#fff;
    }

    .login-page{
        padding:0;
        align-items:flex-start;
    }

    .login-card{
        min-height:100vh;
        max-width:none;
        border-radius:0;
        box-shadow:none;
        padding:25px 18px;
    }

    .login-card h1{
        font-size:28px;
    }

    .login-card h2{
        font-size:22px;
    }
}

.warengruppen-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 20px 0;
}

.wg-button {
    display: inline-block;
    padding: 12px 20px;
    background: #0d6efd;
    color: #fff;
    text-decoration: none;
    border-radius: 8px;
    font-weight: bold;
    text-align: center;
    min-width: 120px;
    transition: all 0.2s ease;
}

.wg-button:hover {
    background: #0b5ed7;
    transform: translateY(-2px);
}

.wg-button.active {
    background: #198754;
    box-shadow: 0 0 10px rgba(25,135,84,0.4);
}
