:root{
    --primary:#1F2937;
    --text:#374151;
    --muted:#6B7280;

    --bg:#F8FAFC;
    --card:#FFFFFF;
    --border:#E5E7EB;

    --success:#22C55E;
    --warning:#F59E0B;
    --danger:#EF4444;
    --info:#3B82F6;

    --radius:18px;
    --shadow:0 14px 35px rgba(15,23,42,.08);
}

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

body{
    background:var(--bg);
    color:var(--text);
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    font-size:16px;
    line-height:1.6;
}

.wrapper{
    width:min(1200px,calc(100% - 40px));
    margin:50px auto;
}

/* ===========================================================
   Header
=========================================================== */

.app-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:40px;
    margin-bottom:34px;
}

.brand{
    flex:1;
}

.brand h1{
    font-size:48px;
    font-weight:800;
    letter-spacing:-.045em;
    line-height:1;
}

.brand span{
    display:block;
    margin-top:12px;
    font-size:18px;
    color:var(--muted);
}

.header-logo{
    flex-shrink:0;
    display:flex;
    align-items:center;
    justify-content:flex-end;
}

.header-logo img{
    max-height:74px;
    max-width:220px;
    width:auto;
    display:block;
    opacity:.9;
}

/* ===========================================================
   Cards
=========================================================== */

.card{
    background:var(--card);
    border:1px solid var(--border);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:32px;
    margin-bottom:24px;
}

h2{
    font-size:28px;
    margin-bottom:20px;
    color:var(--primary);
    letter-spacing:-0.03em;
}

h3{
    color:var(--primary);
}

/* ===========================================================
   Formular
=========================================================== */

.audit-form label{
    display:block;
    font-weight:700;
    margin-bottom:10px;
    color:var(--primary);
}

.form-row{
    display:flex;
    gap:14px;
}

input{
    flex:1;
    min-width:0;

    padding:16px 18px;

    border:1px solid var(--border);
    border-radius:14px;

    font-size:17px;

    background:#fff;
}

input:focus{
    outline:none;
    border-color:var(--info);
}

button{
    border:0;
    border-radius:14px;

    padding:16px 26px;

    background:var(--primary);

    color:#fff;

    font-size:16px;
    font-weight:700;

    cursor:pointer;

    transition:.2s;
}

button:hover{
    opacity:.92;
}

/* ===========================================================
   Result
=========================================================== */

.result-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:20px;
}

.pill{
    display:inline-flex;
    align-items:center;

    padding:8px 15px;

    border-radius:999px;

    background:#EEF2FF;
    color:#3730A3;

    font-weight:700;
}

.info-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:16px;

    margin-top:25px;
}

.info-box{
    padding:18px;

    border-radius:16px;

    background:#F9FAFB;

    border:1px solid var(--border);
}

.info-box span{
    display:block;

    font-size:14px;

    color:var(--muted);

    margin-bottom:8px;
}

.info-box strong{
    display:block;

    color:var(--primary);

    word-break:break-word;
}

/* ===========================================================
   Tabelle
=========================================================== */

.table-wrap{
    overflow:auto;
}

table{
    width:100%;
    border-collapse:collapse;
}

th{
    background:#F9FAFB;
    color:var(--primary);
    font-weight:700;
}

th,
td{
    padding:13px 10px;

    border-bottom:1px solid var(--border);

    text-align:left;
    vertical-align:top;
}

td a{
    color:var(--info);
    text-decoration:none;
}

td a:hover{
    text-decoration:underline;
}

/* ===========================================================
   Alerts
=========================================================== */

.alert{
    padding:16px 18px;
    border-radius:14px;
    font-weight:700;
}

.alert-danger{
    background:#FEE2E2;
    color:#991B1B;
}

.alert-warning{
    background:#FEF3C7;
    color:#92400E;
}

.muted{
    color:var(--muted);
}

/* ===========================================================
   Responsive
=========================================================== */

@media(max-width:900px){

    .info-grid{
        grid-template-columns:repeat(2,1fr);
    }

}

@media(max-width:700px){

    .app-header{
        flex-direction:column;
        align-items:flex-start;
    }

    .brand h1{
        font-size:38px;
    }

    .brand span{
        font-size:17px;
    }

    .header-logo img{
        height:72px;
    }

    .form-row{
        flex-direction:column;
    }

}

@media(max-width:600px){

    .wrapper{
        width:min(100% - 24px,1200px);
        margin:25px auto;
    }

    .card{
        padding:24px;
    }

    .info-grid{
        grid-template-columns:1fr;
    }

}


/* Dashboard */

.score-card{
    background:linear-gradient(135deg,#ffffff 0%,#f8fafc 100%);
}

.score-layout{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:30px;
}

.eyebrow{
    display:block;
    margin-bottom:8px;
    color:var(--muted);
    font-size:14px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.score-circle{
    width:150px;
    height:150px;
    border-radius:50%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    background:conic-gradient(var(--success) calc(var(--score) * 1%),#e5e7eb 0);
    position:relative;
}

.score-circle::before{
    content:"";
    position:absolute;
    inset:12px;
    background:#fff;
    border-radius:50%;
}

.score-circle strong,
.score-circle span{
    position:relative;
    z-index:1;
}

.score-circle strong{
    font-size:46px;
    line-height:1;
    color:var(--primary);
}

.score-circle span{
    color:var(--muted);
    font-weight:700;
}

.score-circle.warning{
    background:conic-gradient(var(--warning) calc(var(--score) * 1%),#e5e7eb 0);
}

.score-circle.danger{
    background:conic-gradient(var(--danger) calc(var(--score) * 1%),#e5e7eb 0);
}

.score-summary{
    margin-top:24px;
    padding-top:22px;
    border-top:1px solid var(--border);
}

.score-summary strong{
    display:block;
    font-size:22px;
    color:var(--primary);
    margin-bottom:5px;
}

.score-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
    margin-bottom:24px;
}

.score-box{
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:24px;
}

.score-box span{
    display:block;
    color:var(--muted);
    font-weight:700;
    margin-bottom:8px;
}

.score-box strong{
    display:block;
    font-size:42px;
    color:var(--primary);
    line-height:1;
    margin-bottom:12px;
}

.score-box p{
    color:var(--muted);
    font-size:14px;
}

.score-box.excellent{
    border-top:5px solid var(--success);
}

.score-box.good{
    border-top:5px solid var(--success);
}

.score-box.warning{
    border-top:5px solid var(--warning);
}

.score-box.danger{
    border-top:5px solid var(--danger);
}

.recommendations{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.recommendation{
    display:flex;
    justify-content:space-between;
    gap:24px;
    padding:20px;
    border:1px solid var(--border);
    border-radius:16px;
    background:#fff;
}

.recommendation h3{
    margin:8px 0 6px;
}

.recommendation p{
    color:var(--muted);
}

.badge{
    display:inline-flex;
    padding:5px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
}

.priority-hoch .badge{
    background:#fee2e2;
    color:#991b1b;
}

.priority-mittel .badge{
    background:#fef3c7;
    color:#92400e;
}

.priority-niedrig .badge{
    background:#dcfce7;
    color:#166534;
}

.recommendation-meta{
    min-width:130px;
    text-align:right;
}

.recommendation-meta strong{
    display:block;
    font-size:22px;
    color:var(--primary);
}

.recommendation-meta span{
    color:var(--muted);
    font-size:14px;
}

@media(max-width:900px){
    .score-grid{
        grid-template-columns:repeat(2,1fr);
    }

    .score-layout,
    .recommendation{
        flex-direction:column;
    }

    .recommendation-meta{
        text-align:left;
    }
}

@media(max-width:600px){
    .score-grid{
        grid-template-columns:1fr;
    }

    .score-circle{
        width:130px;
        height:130px;
    }
}

.positive-list{
    display:flex;
    flex-direction:column;
    gap:16px;
}

.positive-item{
    display:flex;
    align-items:center;
    gap:18px;

    padding:18px 22px;

    background:#f8fafc;
    border:1px solid #e5e7eb;
    border-radius:14px;
}

.positive-icon{
    width:34px;
    height:34px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:#22c55e;
    color:#fff;

    font-size:18px;
    font-weight:700;

    flex-shrink:0;
}

.positive-text{
    font-size:18px;
    color:#1f2937;
    line-height:1.5;
}

.details-box summary{
    cursor:pointer;
    font-size:24px;
    font-weight:800;
    color:var(--primary);
    list-style:none;
}

.details-box summary::-webkit-details-marker{
    display:none;
}

.details-box summary::after{
    content:" anzeigen";
    font-size:15px;
    color:var(--muted);
    font-weight:600;
    margin-left:10px;
}

.details-box[open] summary::after{
    content:" ausblenden";
}

.details-box .table-wrap{
    margin-top:24px;
}