/* IT Warehouse – Awareness-Schulung · Corporate Identity */
:root{
  --orange:#E88B1C; --darkblue:#1A3A5C; --lightblue:#8CCED9; --navy:#162D4D;
  --white:#fff; --lightgray:#F5F5F5; --gray:#B3B3B3; --anthrazit:#333;
  --shadow:0 6px 24px rgba(22,45,77,.10); --radius:14px;
  --ok:#2e9e5b; --warn:#E88B1C; --bad:#d2453a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Open Sans','Segoe UI',Arial,sans-serif;color:var(--anthrazit);
  line-height:1.5;background:var(--lightgray);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{color:var(--darkblue);line-height:1.25;margin:0 0 .5em}
h1{font-size:2rem;font-weight:800} h2{font-size:1.5rem;font-weight:700} h3{font-size:1.2rem}
a{color:var(--darkblue)}
kbd{background:var(--darkblue);color:#fff;border-radius:5px;padding:1px 7px;font-size:.85em;font-family:inherit}

/* Top-Bar */
.topbar{background:var(--darkblue);color:#fff;display:flex;align-items:center;justify-content:space-between;
  padding:12px 26px;box-shadow:var(--shadow);position:sticky;top:0;z-index:50}
.topbar .brand{display:flex;align-items:center;gap:12px;font-weight:700}
.topbar .brand img{height:34px;display:block}
.topbar .brand .sub{font-weight:400;opacity:.8;font-size:.85rem}
.topbar nav a{color:#fff;text-decoration:none;margin-left:18px;opacity:.85;font-size:.95rem}
.topbar nav a:hover{opacity:1;text-decoration:underline}

.wrap{max-width:1000px;margin:0 auto;padding:28px 20px 64px}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;margin-bottom:22px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;border:none;
  padding:12px 24px;border-radius:10px;font-weight:700;font-size:1rem;cursor:pointer;text-decoration:none;transition:.15s}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn.secondary{background:var(--darkblue)}
.btn.ghost{background:transparent;color:var(--darkblue);border:2px solid var(--darkblue)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:saturate(.7)}
@keyframes nextglow{0%,100%{box-shadow:0 0 0 0 rgba(232,139,28,0)}50%{box-shadow:0 0 0 6px rgba(232,139,28,.22)}}
.btn.glow{animation:nextglow 1.6s ease-in-out infinite}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* Forms */
label{display:block;font-weight:600;margin:14px 0 5px;color:var(--darkblue)}
input,select{width:100%;padding:11px 13px;border:1.5px solid #d8dee6;border-radius:9px;font-size:1rem;font-family:inherit}
input:focus,select:focus{outline:none;border-color:var(--orange)}
.muted{color:#7c8794;font-size:.9rem}
.error{background:#fdecea;color:var(--bad);padding:10px 14px;border-radius:9px;margin:12px 0;font-size:.92rem}
.success{background:#e8f6ee;color:var(--ok);padding:10px 14px;border-radius:9px;margin:12px 0}

/* Auth-Layout */
.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--darkblue),var(--navy));padding:20px}
.auth-box{background:#fff;border-radius:18px;box-shadow:0 18px 60px rgba(0,0,0,.3);width:100%;max-width:420px;padding:34px;overflow:hidden}
.auth-box .logo{text-align:center;margin-bottom:8px}
.auth-box .logo img{height:46px}
.auth-box h1{font-size:1.4rem;text-align:center}
.tabs{display:flex;gap:6px;margin:18px 0}
.tabs button{flex:1;background:var(--lightgray);border:none;padding:10px;border-radius:9px;font-weight:700;color:var(--darkblue);cursor:pointer}
.tabs button.active{background:var(--orange);color:#fff}

/* Status-Pills & Badges */
.pill{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.82rem;font-weight:700}
.pill.aktuell{background:#e8f6ee;color:var(--ok)} .pill.offen{background:#eef1f5;color:#5b6876}
.pill.faellig_bald{background:#fff3e0;color:#b5670d} .pill.ueberfaellig{background:#fdecea;color:var(--bad)}
.chip{background:var(--lightblue);color:var(--navy);border-radius:999px;padding:3px 11px;font-size:.8rem;font-weight:700}

/* Dashboard status banner */
.statusbanner{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.statusbanner .big{font-size:2.2rem;font-weight:800;color:var(--darkblue)}

/* Progress */
.progress{height:12px;background:#e7ebf0;border-radius:999px;overflow:hidden}
.progress>div{height:100%;background:linear-gradient(90deg,var(--orange),#f5b04e);width:0;transition:width .4s}

/* Mode cards */
.modegrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.modecard{border:2.5px solid #e1e7ee;border-radius:var(--radius);padding:22px;cursor:pointer;transition:.15s;background:#fff}
.modecard:hover{border-color:var(--lightblue)}
.modecard.sel{border-color:var(--orange);box-shadow:0 0 0 4px rgba(232,139,28,.13)}
.modecard h3{margin-top:0}.modecard .min{color:var(--orange);font-weight:700}

/* Training stage */
.stage{min-height:60vh}
.slide{animation:fade .45s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.lead{font-size:1.15rem;color:var(--navy);font-weight:600}
.highlight{background:linear-gradient(0deg,rgba(232,139,28,.13),rgba(232,139,28,.13));border-left:5px solid var(--orange);
  padding:14px 18px;border-radius:9px;margin:18px 0;font-weight:600;color:var(--navy)}
.warnbox{background:#fff7ed;border:1.5px solid #f3c98a;border-radius:10px;padding:14px 18px;margin:16px 0}
ul.ticks{list-style:none;padding:0} ul.ticks li{padding:7px 0 7px 32px;position:relative}
ul.ticks li::before{content:'✓';position:absolute;left:0;top:6px;color:var(--orange);font-weight:900}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.minibox{background:var(--lightgray);border-radius:11px;padding:16px}
.minibox h4{margin-top:0;color:var(--darkblue)}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cards .c{background:var(--lightgray);border-radius:11px;padding:16px;border-top:4px solid var(--lightblue)}
.cards .c h4{margin:0 0 6px;color:var(--navy)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stats .s{background:var(--darkblue);color:#fff;border-radius:12px;padding:18px;text-align:center}
.stats .s .n{font-size:1.5rem;font-weight:800;color:var(--lightblue)}
.stats .s .l{font-size:.82rem;opacity:.9;margin-top:4px}
.exampw{font-family:'Courier New',monospace;font-size:1.5rem;font-weight:700;color:var(--orange);
  background:var(--navy);padding:12px 18px;border-radius:10px;display:inline-block}

/* Phishing-Simulation */
.mail{border:1.5px solid #dde3ea;border-radius:12px;overflow:hidden;margin:14px 0}
.mail .h{background:var(--lightgray);padding:12px 16px;border-bottom:1px solid #dde3ea;font-size:.92rem}
.mail .h b{color:var(--darkblue)}
.mail .b{padding:18px 16px;line-height:1.7}
.mail .from{cursor:pointer;border-radius:5px;padding:1px 3px}
.flag{cursor:pointer;border-bottom:2px dotted var(--gray);border-radius:3px;padding:0 2px}
.flag.hit{background:#e8f6ee;border-bottom:2px solid var(--ok);color:#1d7a44;font-weight:700}
.flag.found{background:#e8f6ee}

/* Quiz */
.q{margin:18px 0}
.q .opt{display:block;border:1.5px solid #dde3ea;border-radius:10px;padding:13px 16px;margin:9px 0;cursor:pointer;transition:.12s}
.q .opt:hover{border-color:var(--lightblue);background:#fafcfd}
.q .opt.sel{border-color:var(--orange);background:#fff7ed}
.q .opt.correct{border-color:var(--ok);background:#e8f6ee}
.q .opt.wrong{border-color:var(--bad);background:#fdecea}
.feedback{padding:12px 16px;border-radius:9px;margin-top:10px;font-size:.95rem}
.feedback.ok{background:#e8f6ee;color:#1d7a44}.feedback.no{background:#fdecea;color:var(--bad)}

/* Table */
table.data{width:100%;border-collapse:collapse;font-size:.93rem}
table.data th,table.data td{text-align:left;padding:10px 12px;border-bottom:1px solid #eef1f4}
table.data th{color:var(--darkblue);font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
table.data tr:hover td{background:#fafcfd}

/* Audio bar */
.audiobar{display:flex;align-items:center;gap:10px;background:var(--lightgray);border-radius:10px;padding:8px 12px;margin-bottom:16px}
.audiobar button{background:var(--darkblue);color:#fff;border:none;border-radius:8px;width:38px;height:38px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.audiobar button svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.audiobar .label{font-size:.85rem;color:#5b6876}

/* Certificate */
.cert{max-width:800px;margin:30px auto;background:#fff;border:3px solid var(--darkblue);border-radius:14px;padding:48px;text-align:center;position:relative}
.cert::after{content:'';position:absolute;inset:14px;border:1.5px solid var(--lightblue);border-radius:8px;pointer-events:none}
.cert h1{font-size:2rem;color:var(--darkblue)} .cert .name{font-size:1.8rem;color:var(--orange);font-weight:800;margin:14px 0}
.cert .seal{font-size:3rem}
@media print{.topbar,.no-print{display:none!important}body,body.dark-stage{background:#fff!important}}

/* ===================== Animationen ===================== */
@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.05)}100%{transform:scale(1)}}
@keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-6px)}40%,60%{transform:translateX(6px)}}
@keyframes attn{0%,100%{box-shadow:0 0 0 0 rgba(232,139,28,0)}35%{box-shadow:0 0 0 4px rgba(232,139,28,.18)}}
@keyframes shimmer{to{transform:translateX(100%)}}
@keyframes eqbar{0%,100%{height:5px}50%{height:16px}}
@keyframes flagpulse{0%,100%{background:transparent}50%{background:rgba(232,139,28,.13)}}
@keyframes fall{to{transform:translateY(440px) rotate(560deg);opacity:0}}
@keyframes stampIn{0%{transform:scale(2.4) rotate(-18deg);opacity:0}55%{transform:scale(.9) rotate(5deg);opacity:1}100%{transform:scale(1) rotate(0)}}

/* Gestaffeltes Einblenden der Folieninhalte */
.slide>*{animation:riseIn .5s both}
.slide>*:nth-child(2){animation-delay:.05s}.slide>*:nth-child(3){animation-delay:.10s}
.slide>*:nth-child(4){animation-delay:.15s}.slide>*:nth-child(5){animation-delay:.20s}
.slide>*:nth-child(6){animation-delay:.25s}.slide>*:nth-child(n+7){animation-delay:.30s}
ul.ticks li{animation:riseIn .45s both}
ul.ticks li:nth-child(2){animation-delay:.07s}ul.ticks li:nth-child(3){animation-delay:.14s}
ul.ticks li:nth-child(4){animation-delay:.21s}ul.ticks li:nth-child(5){animation-delay:.28s}
ul.ticks li:nth-child(6){animation-delay:.35s}ul.ticks li:nth-child(n+7){animation-delay:.42s}
.cards .c,.stats .s,.twocol .minibox{animation:riseIn .5s both}
.cards .c:nth-child(2),.stats .s:nth-child(2),.twocol .minibox:nth-child(2){animation-delay:.10s}
.stats .s:nth-child(3){animation-delay:.20s}.stats .s:nth-child(4){animation-delay:.30s}
.highlight{animation:riseIn .5s both,attn 1.5s ease .55s 1}
.warnbox{animation:riseIn .5s both}
.feedback{animation:riseIn .35s both}

/* Fortschrittsbalken-Shimmer */
#bar{position:relative;overflow:hidden}
#bar::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:translateX(-100%);animation:shimmer 2.4s ease-in-out infinite}

/* Audio-Equalizer (nur aktiv, während Dana spricht) */
.audiobar .eq{display:inline-flex;align-items:flex-end;gap:2px;height:16px;margin-left:2px}
.audiobar .eq i{width:3px;height:5px;background:var(--orange);border-radius:2px}
.audiobar.playing .eq i{animation:eqbar .85s ease-in-out infinite}
.audiobar.playing .eq i:nth-child(2){animation-delay:.18s}
.audiobar.playing .eq i:nth-child(3){animation-delay:.36s}
.audiobar.playing .eq i:nth-child(4){animation-delay:.12s}

/* Quiz- & Szenario-Feedback */
.q .opt.correct{animation:pop .45s}
.q .opt.wrong{animation:shake .4s}

/* Phishing-Hinweise */
.mail .flag:not(.found){animation:flagpulse 2.6s ease-in-out infinite}
.mail .flag.hit{animation:pop .4s}

/* Abschluss-Ring & Konfetti */
.ring{transform:rotate(-90deg)}
.ring .fg{transition:stroke-dashoffset 1.1s cubic-bezier(.3,.7,.3,1)}
.confetti{position:absolute;top:-12px;width:9px;height:14px;border-radius:2px;will-change:transform,opacity;animation:fall linear forwards}

/* Zertifikats-Siegel */
.cert .seal{display:inline-block;animation:stampIn .7s cubic-bezier(.2,.8,.3,1.2) both}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}
  #bar::after,.audiobar.playing .eq i,.mail .flag:not(.found){animation:none!important}
}
/* ======================================================= */

/* ===================== Visuelles Redesign ===================== */
.modhero{display:flex;align-items:center;gap:16px;background:var(--darkblue);color:#fff;border-radius:14px;padding:18px 22px;margin-bottom:22px}
.modhero .ic{flex:none;width:58px;height:58px;border-radius:14px;background:rgba(255,255,255,.13);display:flex;align-items:center;justify-content:center}
.modhero .ic svg{width:32px;height:32px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.bi svg{width:20px;height:20px;vertical-align:-4px;margin-right:8px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.warnbox .bi{color:#b5670d} .highlight .bi{color:var(--orange)}
.resicon{display:inline-block;margin-bottom:4px}
.resicon svg{width:56px;height:56px;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.resicon.ok svg{stroke:var(--ok)} .resicon.no svg{stroke:var(--orange)}
.modhero .lbl{font-size:.72rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--lightblue);font-weight:700}
.modhero h2{color:#fff;margin:2px 0 0;font-size:1.5rem}

/* Icon-Kacheln statt Aufzählungen */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin:18px 0}
.tile{display:flex;gap:13px;align-items:center;background:var(--lightgray);border-radius:12px;padding:14px 16px;border-left:4px solid var(--lightblue)}
.tile .tic{flex:none;width:42px;height:42px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--darkblue)}
.tile .tic svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tile .tic .num{font-weight:800;font-size:1.05rem;color:var(--orange)}
.tile .tx{font-size:.96rem;line-height:1.45}
.tile.accent{border-left-color:var(--orange)} .tile.accent .tic{color:var(--orange)}
.tile.do{border-left-color:var(--ok)} .tile.do .tic{color:var(--ok)}
.tile.dont{border-left-color:var(--bad);background:#fdecea} .tile.dont .tic{color:var(--bad)}

/* Signatur-Visuals */
.hexwrap{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:20px 0}
.hexitem{width:128px;text-align:center;animation:riseIn .5s both}
.hexitem:nth-child(2){animation-delay:.07s}.hexitem:nth-child(3){animation-delay:.14s}
.hexitem:nth-child(4){animation-delay:.21s}.hexitem:nth-child(5){animation-delay:.28s}
.hexitem:nth-child(6){animation-delay:.35s}.hexitem:nth-child(7){animation-delay:.42s}
.hexitem .hx{width:84px;height:94px;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;color:#fff;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);background:var(--darkblue)}
.hexitem:nth-child(even) .hx{background:var(--navy)}
.hexitem .hx svg{width:34px;height:34px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.hexitem .hl{font-size:.82rem;color:var(--darkblue);font-weight:700;line-height:1.25}

.pwmeter{max-width:440px;margin:18px auto}
.pwmeter .track{height:16px;border-radius:999px;background:#e7ebf0;overflow:hidden}
.pwmeter .fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,#d2453a,#E88B1C,#2e9e5b)}
.pwmeter .scale{display:flex;justify-content:space-between;font-size:.76rem;color:#7c8794;margin-top:7px}
.pwmeter .scale b{color:var(--ok)}

.shieldwrap{display:flex;justify-content:center;margin:10px 0 4px}
.shieldwrap canvas{width:min(380px,82%);height:auto;display:block}

/* Dunkle App-Bühne (alle Seiten): getöntes Navy hinter hellen Lesekarten */
body.dark-stage{background:#11243B}
body.dark-stage .card{box-shadow:0 10px 34px rgba(0,0,0,.28)}
/* nur Ghost-Buttons direkt auf dunklem Grund (Navigation/Zertifikat), NICHT in weißen Karten */
body.dark-stage .wrap > .btn-row .btn.ghost{color:#fff;border-color:rgba(255,255,255,.55)}
body.dark-stage .wrap > .btn-row .btn.ghost:hover{background:rgba(255,255,255,.08)}
/* freistehende Seitentitel (außerhalb von Karten) auf dunklem Grund */
body.dark-stage .page-title{color:#fff}
body.dark-stage .page-sub{color:#bcd0e0}
/* Kennzahl-Kacheln (Admin) klar vom dunklen Grund abheben */
body.dark-stage .stats .s{background:#1f3e60;border:1px solid rgba(140,206,217,.18)}

/* Willkommens-Hero (1:1 Claude-Design) – dunkles Panel, randlos in der Stage-Card */
.hero{position:relative;margin:-28px;border-radius:var(--radius);background:#1A3A5C;overflow:hidden;
  font-family:'Open Sans',Arial,sans-serif;display:flex;align-items:center;min-height:520px}
/* Audioleiste im Hero (dunkel statt hellgrau darüber) */
.hero .audiobar{background:rgba(255,255,255,.08);margin:clamp(16px,2.4vw,24px) 0 0;max-width:430px}
.hero .audiobar .label{color:#bfdfe7}
.hero .audiobar #ttsbtn{background:#E88B1C}
.hero-hex{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.05;pointer-events:none}
.hero-mark{position:absolute;top:clamp(18px,3vw,32px);left:clamp(22px,5vw,44px);z-index:3;display:flex;align-items:center;gap:10px}
.hero-mark span:last-child{color:#fff;font-weight:700;font-size:clamp(13px,1vw,15px);letter-spacing:.04em}
.hero-grid{position:relative;z-index:2;display:flex;width:100%;align-items:center;gap:clamp(20px,4vw,56px);
  padding:clamp(28px,5vw,56px);padding-top:clamp(66px,8vw,84px)}
.hero-text{flex:1 1 0;min-width:0;max-width:600px}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:clamp(12px,2vw,18px)}
.hero-eyebrow span:last-child{font-size:clamp(11px,1vw,14px);letter-spacing:.18em;text-transform:uppercase;color:#8CCED9;font-weight:600}
.hero h1{margin:0 0 clamp(12px,2vw,20px);font-size:clamp(26px,3.3vw,46px);line-height:1.12;font-weight:800;color:#fff;letter-spacing:-.01em}
.hero p{margin:0 0 clamp(18px,3vw,26px);font-size:clamp(15px,1.4vw,19px);line-height:1.6;color:rgba(255,255,255,.8);max-width:48ch}
.hero-chips{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;font-size:clamp(12px,1vw,15px);color:#8CCED9;font-weight:600}
.hero-chips .dot{opacity:.4}.hero-chips .hl{color:#fff}
.hero-canvas{flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.hero-canvas canvas{width:clamp(220px,30vw,340px);height:auto;display:block}
@media(max-width:760px){
  .hero-grid{flex-direction:column;align-items:flex-start}
  .hero-canvas{align-self:center;order:2}
}

.clock{display:block;margin:6px auto 2px}
.clock .needle{transform-origin:60px 60px}
.clockcap{text-align:center;font-weight:700;color:var(--darkblue)}

.viz-row{display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:center}

/* Passwort-Schloss (rot/offen → grün/zu) */
.pwrow{display:flex;align-items:center;gap:14px}
.pwrow .track{flex:1}
.pwlock{flex:none;width:42px;height:42px;border-radius:50%;background:#fff;box-shadow:0 0 0 2px #f1d4d0;display:flex;align-items:center;justify-content:center;color:#d2453a;transition:color .4s,box-shadow .4s}
.pwlock svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pwlock.snap{color:var(--ok);box-shadow:0 0 0 2px #bfe6cd;animation:lockSnap .5s cubic-bezier(.2,.8,.3,1.4)}
@keyframes lockSnap{0%{transform:scale(.8)}55%{transform:scale(1.15)}100%{transform:scale(1)}}

/* Seitenwechsel (Page Transition) */
#stage{transition:opacity .16s ease, transform .16s ease}
#stage.pageout-fwd{opacity:0;transform:translateX(-24px)}
#stage.pageout-back{opacity:0;transform:translateX(24px)}

/* Phishing-Sortierung */
.sortbaskets{display:flex;gap:14px;margin:14px 0}
.basket{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:12px;font-weight:700}
.basket .bk svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-4px}
.basket.safe{background:#e8f6ee;color:#1d7a44;border:1.5px solid #bfe6cd}
.basket.bad{background:#fdecea;color:#a3302a;border:1.5px solid #f3c0bb}
.basket .cnt{background:#fff;border-radius:999px;min-width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem}
.smails{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.smail{background:var(--lightgray);border-radius:12px;padding:12px 14px;border-left:4px solid var(--gray);transition:opacity .4s,transform .4s}
.smail .sm-from{font-weight:700;color:var(--darkblue);font-size:.9rem}
.smail .sm-subj{color:#555;font-size:.9rem;margin-top:2px}
.smail .sm-act{display:flex;gap:10px;margin-top:10px}
.sbtn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1.5px solid #d8dee6;background:#fff;border-radius:9px;padding:9px;font-weight:700;cursor:pointer;color:var(--darkblue)}
.sbtn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sbtn.safe:hover{border-color:#2e9e5b;color:#1d7a44}.sbtn.bad:hover{border-color:#d2453a;color:#a3302a}
.sbtn:disabled{opacity:.5;cursor:default}
.smail.solved{opacity:.6;border-left-color:var(--ok);animation:settle .4s}
.smail.solved.to-bad{border-left-color:var(--bad)}
.smail.solved .sm-act{display:none}
.smail.wrongflash{animation:shake .4s, redflash .55s}
@keyframes settle{0%{transform:scale(1)}40%{transform:scale(.97)}100%{transform:scale(1)}}
@keyframes redflash{0%,100%{background:var(--lightgray)}30%{background:#fdecea}}

/* KI-Scan-Strahl über dem Modulkopf */
.slide.mod-ki .modhero{position:relative;overflow:hidden}
.slide.mod-ki .modhero::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(140,206,217,.45),transparent 70%);transform:translateX(-110%);animation:scan 1.5s ease-out .2s 1}
@keyframes scan{to{transform:translateX(110%)}}
/* ============================================================= */

@media(max-width:720px){
  .modegrid,.twocol,.cards,.stats{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .wrap{padding:18px 14px 48px}
}
