:root{--blue:#015da9;--blue2:#014f91;--orange:#ef7c01;--orange2:#ff9f2e;--ink:#172033;--muted:#667085;--line:#d9e2ec;--bg:#f4f7fb;--card:#fff;--ok:#197b30;--bad:#b42318;--shadow:0 18px 60px rgba(1,93,169,.16);--radius:24px}*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:radial-gradient(circle at top left,rgba(239,124,1,.16),transparent 28rem),linear-gradient(135deg,#f8fbff,#eef4fb 58%,#fff7ed);color:var(--ink);min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:28px 18px 44px}header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:26px}.brand{display:flex;align-items:center;gap:18px}.logo{height:58px;max-width:240px;object-fit:contain}.brand h1{font-size:20px;line-height:1.15;margin:0;color:var(--blue);letter-spacing:.2px}.brand p{margin:4px 0 0;color:var(--muted);font-size:13px}.top-pill{border:1px solid rgba(1,93,169,.18);background:rgba(255,255,255,.72);border-radius:999px;padding:10px 14px;color:var(--blue);font-weight:700;font-size:13px;white-space:nowrap}.card{background:var(--card);border:1px solid rgba(1,93,169,.12);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.hero{padding:34px;background:linear-gradient(135deg,var(--blue),#062a4d);color:#fff;position:relative}.hero:after{content:"";position:absolute;right:-60px;top:-60px;width:180px;height:180px;border-radius:50%;background:rgba(239,124,1,.35)}.hero h2{margin:0;font-size:32px}.hero p{margin:10px 0 0;color:rgba(255,255,255,.86);max-width:720px}.content{padding:30px}.grid{display:grid;grid-template-columns:300px 1fr;gap:20px}.side{background:rgba(255,255,255,.74);backdrop-filter:blur(10px);border:1px solid rgba(1,93,169,.12);border-radius:var(--radius);padding:20px;box-shadow:0 10px 32px rgba(1,93,169,.08);align-self:start;position:sticky;top:18px}.field{margin-bottom:14px}.field label{display:block;color:var(--muted);font-size:12px;font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px 13px;font-size:15px;outline:none;background:#fff;font-family:Arial,Helvetica,sans-serif}.field input:focus,.field textarea:focus{border-color:var(--blue2);box-shadow:0 0 0 4px rgba(1,93,169,.12)}.btn{border:0;border-radius:15px;padding:13px 18px;font-weight:800;cursor:pointer;font-size:15px;text-decoration:none;display:inline-flex;align-items:center}.btn.secondary{background:#edf3f9;color:var(--blue)}.btn.primary{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#201000;box-shadow:0 10px 24px rgba(239,124,1,.28)}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.progress-wrap{margin-top:18px}.progress-label{display:flex;justify-content:space-between;color:var(--muted);font-size:13px;margin-bottom:8px}.bar{height:10px;background:#e7eef6;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--orange));transition:.25s}.dots{display:grid;grid-template-columns:repeat(6,1fr);gap:7px;margin-top:16px}.dot{border:1px solid var(--line);background:#fff;color:var(--muted);height:34px;border-radius:11px;font-weight:700}.dot.active{background:var(--blue);color:#fff;border-color:var(--blue)}.dot.done{border-color:rgba(239,124,1,.55);box-shadow:inset 0 -3px 0 var(--orange)}.hint{margin-top:18px;color:var(--muted);font-size:13px;line-height:1.45}.meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.badge{background:rgba(239,124,1,.14);color:#8a4a00;border:1px solid rgba(239,124,1,.28);border-radius:999px;padding:8px 12px;font-weight:700;font-size:13px}.q-title{font-size:23px;line-height:1.33;margin:0 0 10px;color:var(--blue)}.q-sub{color:var(--muted);font-weight:700;margin:0 0 22px}.answers{display:grid;gap:12px}.answer{display:flex;gap:12px;align-items:flex-start;padding:15px 16px;border:1px solid var(--line);border-radius:16px;background:#fff;cursor:pointer;transition:.18s}.answer:hover{border-color:var(--orange);transform:translateY(-1px)}.answer input{margin-top:3px;accent-color:var(--orange)}.answer strong{color:var(--blue)}.nav{display:flex;justify-content:space-between;gap:12px;margin-top:24px}.result h2{color:var(--blue);font-size:30px;margin:0 0 8px}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0}.kpi{border:1px solid var(--line);border-radius:18px;padding:16px;background:#fbfdff}.kpi span{display:block;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase}.kpi b{font-size:22px;color:var(--blue)}.certificate{margin-top:24px;border:2px solid var(--blue);border-radius:22px;padding:28px;background:linear-gradient(135deg,#fff,#f7fbff);position:relative;overflow:hidden}.certificate:before{content:"";position:absolute;right:-50px;bottom:-50px;width:160px;height:160px;border-radius:50%;background:rgba(239,124,1,.18)}.certificate h3{margin:0 0 12px;font-size:28px;color:var(--blue)}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:18px;overflow:hidden}.admin-table th,.admin-table td{border-bottom:1px solid var(--line);padding:12px;text-align:left;font-size:14px}.admin-table th{background:#eef5fb;color:var(--blue);text-transform:uppercase;font-size:12px}.status{font-weight:800}.status.bestanden{color:var(--ok)}.status.nicht{color:var(--bad)}.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.error{background:#fff1f0;color:var(--bad);padding:12px;border-radius:14px;font-weight:800;margin-top:12px}.hidden{display:none!important}.admin-section{margin-top:20px}.security-list{display:grid;gap:10px;margin-top:16px}.security-item{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff}.security-item b{display:block;color:var(--blue);margin-bottom:4px}.security-item span{color:var(--muted)}.security-item.ok{border-left:6px solid var(--ok)}.security-item.warn{border-left:6px solid var(--orange)}.security-item.info{border-left:6px solid var(--blue)}@media print{body{background:#fff}header,.side,.nav,.actions,.top-pill{display:none}.app{padding:0}.card{box-shadow:none;border:0}.hero{display:none}.grid{display:block}.certificate{page-break-inside:avoid}}@media(max-width:850px){.grid{grid-template-columns:1fr}.side{position:static}.result-grid{grid-template-columns:1fr}.hero h2{font-size:24px}.q-title{font-size:20px}.logo{max-width:180px}.brand{align-items:flex-start}}

/* ── Result status banner ─────────────────────────────────────── */
.res-status{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:18px;margin-bottom:6px}
.res-status.res-passed{background:rgba(25,123,48,.1);border:1px solid rgba(25,123,48,.3)}
.res-status.res-failed{background:rgba(180,35,24,.08);border:1px solid rgba(180,35,24,.2)}
.res-status h2{font-size:28px!important;margin:0 0 4px!important}
.res-status.res-passed h2{color:var(--ok)!important}
.res-status.res-failed h2{color:var(--bad)!important}
.res-status p{margin:0;color:var(--muted);font-size:14px}
.res-status-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900;flex-shrink:0;color:#fff}
.res-status.res-passed .res-status-icon{background:var(--ok)}
.res-status.res-failed .res-status-icon{background:var(--bad)}

/* ── Email notice ─────────────────────────────────────────────── */
.email-notice{display:flex;align-items:center;gap:12px;background:rgba(239,124,1,.1);border:1px solid rgba(239,124,1,.3);border-radius:14px;padding:14px 18px;color:#6b3600;font-size:14px;line-height:1.45;margin:14px 0}
.email-notice-icon{font-size:22px;flex-shrink:0}

/* ── Failed hint ──────────────────────────────────────────────── */
.failed-hint{background:rgba(180,35,24,.06);border:1px solid rgba(180,35,24,.2);border-radius:16px;padding:18px;color:var(--bad);font-size:14px;line-height:1.6;margin-top:14px}

/* ── Premium Certificate ──────────────────────────────────────── */
.cert-premium{margin-top:20px;border:2px solid var(--blue);border-radius:22px;overflow:hidden;box-shadow:0 24px 64px rgba(1,93,169,.18);background:#fff}
.cert-top{background:linear-gradient(135deg,#00284d 0%,#015da9 100%);padding:26px 32px;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.cert-top::before{content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:50%;background:rgba(239,124,1,.22)}
.cert-top::after{content:"";position:absolute;right:30px;bottom:-30px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.06)}
.cert-brand-logo{height:46px;max-width:160px;object-fit:contain;position:relative;z-index:1;background:#fff;padding:6px 12px;border-radius:8px}
.cert-top-text{flex:1;position:relative;z-index:1}
.cert-top-label{display:block;color:#fff;font-size:24px;font-weight:900;letter-spacing:.4px}
.cert-top-sub{display:block;color:rgba(255,255,255,.72);font-size:13px;margin-top:3px}
.cert-pct-badge{position:relative;z-index:1;background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;font-size:24px;font-weight:900;width:76px;height:76px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(239,124,1,.45);flex-shrink:0;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.cert-pct-badge span{font-size:14px;font-weight:700;margin-top:-4px}
.cert-stripe{height:6px;background:linear-gradient(90deg,var(--orange),var(--orange2),var(--orange));-webkit-print-color-adjust:exact;print-color-adjust:exact}
.cert-body{padding:32px;background:linear-gradient(160deg,#fff 70%,#f7f9ff)}
.cert-intro-text{margin:0 0 6px;color:var(--muted);font-size:13px}
.cert-recipient{font-size:34px;font-weight:900;color:var(--blue);line-height:1.15;margin-bottom:4px}
.cert-recipient-company{margin:0 0 2px;color:var(--orange);font-size:15px;font-weight:700}
.cert-recipient-email{margin:0 0 20px;color:var(--muted);font-size:14px}
.cert-description{margin:0 0 26px;color:var(--ink);font-size:14px;line-height:1.65;padding-bottom:24px;border-bottom:1px solid var(--line)}
.cert-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px}
.cert-metric{background:#f4f7fb;border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center}
.cert-metric.cert-metric-hi{background:linear-gradient(135deg,rgba(239,124,1,.13),rgba(255,159,46,.07));border-color:rgba(239,124,1,.35)}
.cert-metric-val{display:block;font-size:22px;font-weight:900;color:var(--blue)}
.cert-metric-hi .cert-metric-val{color:var(--orange)}
.cert-metric-lbl{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-top:4px}
.cert-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.cert-seal{flex-shrink:0}
.cert-seal-ring{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange2));display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(239,124,1,.38);border:3px solid rgba(255,255,255,.4);-webkit-print-color-adjust:exact;print-color-adjust:exact}
.cert-seal-top,.cert-seal-btm{color:#fff;font-size:9px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.cert-seal-mid{color:#fff;font-size:26px;font-weight:900;line-height:1}
.cert-id-wrap{text-align:right}
.cert-id-lbl{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:5px}
.cert-id-val{display:block;color:var(--blue);font-size:14px;font-weight:800;letter-spacing:.5px}

/* ── Admin filter bar ─────────────────────────────────────────── */
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.filter-bar input,.filter-bar select{border:1px solid var(--line);border-radius:12px;padding:9px 13px;font-size:14px;outline:none;background:#fff;font-family:Arial,Helvetica,sans-serif;color:var(--ink)}
.filter-bar input{flex:1;min-width:180px}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(1,93,169,.1)}
.filter-count{color:var(--muted);font-size:13px;white-space:nowrap}

/* ── Certificate modal ────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto}
.modal-box{background:#fff;border-radius:24px;box-shadow:0 32px 96px rgba(0,0,0,.28);max-width:760px;width:100%;position:relative}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:0;background:rgba(0,0,0,.08);cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;z-index:10;color:var(--ink)}
.modal-close:hover{background:rgba(0,0,0,.16)}
.modal-actions{display:flex;gap:10px;padding:20px 24px;border-top:1px solid var(--line);flex-wrap:wrap}

/* ── Print rules (updated) ────────────────────────────────────── */
@media print{
  body{background:#fff}
  header,.side,.nav,.actions,.top-pill,.email-notice,.res-status,.result-grid,.filter-bar,.modal-overlay{display:none!important}
  .app{padding:0}
  .card{box-shadow:none;border:0}
  .hero{display:none}
  .grid{display:block}
  .cert-premium{page-break-inside:avoid;margin:0;border-radius:0;border:none;box-shadow:none}
  .content{padding:0}
}

@media(max-width:680px){
  .cert-top{flex-wrap:wrap;padding:20px}
  .cert-metrics{grid-template-columns:1fr}
  .cert-bottom-row{flex-direction:column;align-items:flex-start}
  .cert-id-wrap{text-align:left}
  .cert-recipient{font-size:26px}
}
