/* mx-it Assessment Center — CI 2026
   Farben, Typo und Designelemente gemaess Corporate Identity Manual. */
:root{
  --navy:#151d32;
  --bg:#f3f6fb;
  --white:#ffffff;
  --grey:#f2f2f2;
  --black:#121212;
  --signal:#476cf2;
  --signal-d:#2f4fd0;
  /* Akzente */
  --teal:#c4e3e5; --peach:#f8dbad; --yellow:#fafcc3;
  --pink:#e79eb9; --sky:#c3eeff; --lavender:#d8b7de;
  --ok:#1f9d6b; --ok-bg:#e3f6ee;
  --bad:#d4434f; --bad-bg:#fbe5e7;
  --line:#e4e9f2;
  --muted:#5c6680;
  --radius:16px;
  --shadow:0 10px 30px rgba(21,29,50,.08);
  --font-h:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-b:'Arimo',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-b);
  color:var(--navy);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.h{font-family:var(--font-h);font-weight:700;line-height:1.2;color:var(--navy)}
h1{font-size:1.9rem;margin:.2em 0 .4em}
h2{font-size:1.3rem}
h3{font-size:1.05rem}
a{color:var(--signal-d);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.small{font-size:.86rem}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* Layout */
.container{max-width:1080px;margin:0 auto;padding:28px 22px}
.wrap-narrow{max-width:560px;margin:0 auto;padding:28px 22px}
.topbar{
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;
}
.topbar .brand{display:flex;align-items:center;gap:12px;font-family:var(--font-h);font-weight:600;color:#fff}
.topbar img.logo{height:26px}
.topbar nav a{color:#cdd6ee;margin-left:18px;font-family:var(--font-h);font-size:.92rem}
.topbar nav a:hover{color:#fff;text-decoration:none}

/* Cards */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.card + .card{margin-top:18px}
.grid{display:grid;gap:16px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:680px){.grid.cols-2{grid-template-columns:1fr}}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-family:var(--font-h);font-weight:600;font-size:.95rem;
  background:var(--signal);color:#fff;border:none;border-radius:12px;
  padding:12px 22px;cursor:pointer;transition:.15s;text-decoration:none;
}
.btn:hover{background:var(--signal-d);text-decoration:none;color:#fff}
.btn.secondary{background:#fff;color:var(--navy);border:1px solid var(--line)}
.btn.secondary:hover{background:var(--grey)}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn.lg{padding:16px 30px;font-size:1.05rem;border-radius:14px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* Forms */
label.field{display:block;margin:14px 0}
label.field > span{display:block;font-family:var(--font-h);font-weight:500;font-size:.86rem;margin-bottom:6px;color:var(--navy)}
input[type=text],input[type=email],input[type=password],input[type=number],select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;
  font-family:var(--font-b);font-size:1rem;background:#fff;color:var(--navy);
}
input:focus,select:focus{outline:none;border-color:var(--signal);box-shadow:0 0 0 3px rgba(71,108,242,.15)}
.help{font-size:.82rem;color:var(--muted)}

/* Badges */
.badge{display:inline-block;font-family:var(--font-h);font-size:.72rem;font-weight:600;
  padding:3px 10px;border-radius:999px;background:var(--grey);color:var(--navy)}
.badge.blue{background:rgba(71,108,242,.12);color:var(--signal-d)}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.bad{background:var(--bad-bg);color:var(--bad)}
.badge.warn{background:var(--peach);color:#7a4a12}

/* Tables */
table{width:100%;border-collapse:collapse;font-size:.95rem}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{font-family:var(--font-h);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
tr:hover td{background:#fafcff}

/* Accent stripe (CI) */
.stripe{height:5px;border-radius:6px;background:linear-gradient(90deg,var(--signal),var(--navy));margin:0 0 18px}

/* Auth pages */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 70% -10%,#21304f 0%,var(--navy) 55%)}
.auth-card{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 24px 60px rgba(0,0,0,.35);padding:34px}
.auth-card .logo{height:30px;margin-bottom:8px}
.alert{background:var(--bad-bg);color:var(--bad);border-radius:12px;padding:10px 14px;font-size:.9rem;margin:10px 0}
.notice{background:var(--sky);color:#0c4a63;border-radius:12px;padding:10px 14px;font-size:.9rem;margin:10px 0}

/* Skill picker */
.skill-row{display:grid;grid-template-columns:1fr 320px;gap:14px;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--line)}
.skill-row .meta{font-size:.8rem;color:var(--muted)}
.levels{display:flex;gap:6px;flex-wrap:wrap}
.levels label{flex:1;min-width:64px}
.levels input{position:absolute;opacity:0}
.levels span{display:block;text-align:center;font-family:var(--font-h);font-size:.78rem;font-weight:600;
  padding:8px 6px;border:1px solid var(--line);border-radius:10px;cursor:pointer;color:var(--muted);background:#fff}
.levels input:checked + span{background:var(--signal);color:#fff;border-color:var(--signal)}
.levels label.lv-none input:checked + span{background:var(--grey);color:var(--navy);border-color:var(--line)}
.cat-title{font-family:var(--font-h);font-weight:700;color:var(--navy);margin:22px 0 4px;font-size:.95rem}

/* Exam */
.exam-body{background:var(--bg)}
.exam-top{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;position:sticky;top:0;z-index:5}
.exam-top .logo{height:22px}
.timer{font-family:var(--font-h);font-weight:600;background:rgba(255,255,255,.1);padding:7px 14px;border-radius:10px}
.timer.warn{background:var(--bad);color:#fff}
.exam-grid{display:grid;grid-template-columns:1fr 240px;gap:22px;max-width:1080px;margin:0 auto;padding:24px 22px}
@media(max-width:820px){.exam-grid{grid-template-columns:1fr}}
.q-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;min-height:340px}
.q-stem{font-size:1.12rem;font-weight:500;margin:8px 0 18px;font-family:var(--font-b)}
.opt{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:12px;padding:13px 15px;margin:9px 0;cursor:pointer;transition:.12s;background:#fff}
.opt:hover{border-color:#b9c6ec;background:#fafcff}
.opt.sel{border-color:var(--signal);background:rgba(71,108,242,.07)}
.opt .box{width:22px;height:22px;border:2px solid #b9c6ec;border-radius:6px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;margin-top:1px}
.opt.single .box{border-radius:50%}
.opt.sel .box{border-color:var(--signal);background:var(--signal)}
.opt.sel .box::after{content:"";width:9px;height:9px;background:#fff;border-radius:2px}
.opt.single.sel .box::after{border-radius:50%}
.q-nav{display:flex;justify-content:space-between;margin-top:22px;gap:10px}
.side{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;height:fit-content;position:sticky;top:78px}
.side h4{margin:0 0 10px}
.qjump{display:grid;grid-template-columns:repeat(6,1fr);gap:7px}
.qjump button{aspect-ratio:1;border:1px solid var(--line);background:#fff;border-radius:8px;font-family:var(--font-h);font-size:.8rem;cursor:pointer;color:var(--muted)}
.qjump button.answered{background:var(--navy);color:#fff;border-color:var(--navy)}
.qjump button.flagged{border-color:var(--peach);box-shadow:inset 0 0 0 2px var(--peach)}
.qjump button.current{outline:2px solid var(--signal);outline-offset:1px;color:var(--signal);font-weight:700}
.flag-btn{background:none;border:none;color:var(--muted);font-family:var(--font-h);font-size:.85rem;cursor:pointer}
.flag-btn.on{color:#b5731a}

/* Welcome */
.welcome-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 700px at 50% -10%,#22304f,var(--navy) 60%);color:#fff;text-align:center;padding:30px}
.welcome-card{max-width:640px}
.memoji-bubble{width:128px;height:128px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;
  background:var(--teal);box-shadow:0 18px 50px rgba(0,0,0,.4);overflow:hidden}
.memoji-bubble img{width:112px;height:112px;object-fit:contain}
.welcome-card h1{color:#fff;font-size:2.4rem;margin:.4em 0 .1em}
.welcome-card .lead{font-size:1.15rem;color:#d3ddf3;max-width:520px;margin:0 auto 26px}
.welcome-card .hl{color:#9db4ff}
.fade-up{opacity:0;transform:translateY(16px);animation:fadeUp .7s ease forwards}
.d1{animation-delay:.15s}.d2{animation-delay:.45s}.d3{animation-delay:.8s}.d4{animation-delay:1.15s}
@keyframes fadeUp{to{opacity:1;transform:none}}
.pop{animation:pop .6s cubic-bezier(.2,.9,.3,1.3) forwards;opacity:0;transform:scale(.6)}
@keyframes pop{to{opacity:1;transform:scale(1)}}
.meta-pills{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:18px 0 4px}
.meta-pills .pill{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);padding:8px 14px;border-radius:999px;font-family:var(--font-h);font-size:.82rem}
.apple-partner{height:30px;opacity:.95;margin-top:26px}

/* Result */
.score-ring{width:200px;height:200px;margin:0 auto}
.result-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:30px;text-align:center}
.result-card{max-width:560px;background:#fff;border-radius:24px;box-shadow:var(--shadow);padding:40px}

.footer{ text-align:center;color:var(--muted);font-size:.8rem;padding:26px}
.flex{display:flex}.between{justify-content:space-between}.items-center{align-items:center}.gap{gap:12px}
.mt{margin-top:16px}.mt2{margin-top:26px}.mb0{margin-bottom:0}
.right{text-align:right}
