/* ═══════════════════════════════════════════════════
   LGG German Complete — Duolingo-style UI  v3
═══════════════════════════════════════════════════ */
:root {
  --bg:#f7f8fa; --white:#fff; --s1:#f0f2f5; --s2:#e8eaf0;
  --border:#d9dbe5; --border2:#c8cad8;
  --acc:#58cc02; --acc-dk:#46a302; --acc-lt:#d7f5b0;
  --blue:#1cb0f6; --blue-dk:#0891cc;
  --red:#ff4b4b; --red-lt:#ffdfe0;
  --gold:#ffc800; --pur:#ce82ff; --org:#ff9600;
  --txt:#3c3c3c; --txt2:#777; --txt3:#afafaf;
  --nav-bg:#fff; --nav-h:60px;
  --path-w:480px;
  --r:16px; --r-sm:10px; --r-lg:24px;
  --shadow:0 2px 0 rgba(0,0,0,.2);
  --shadow-up:0 -2px 0 rgba(0,0,0,.15);
  --transition:.18s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font-family:'Nunito',sans-serif;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── BACK BAR ── */
.lgc-back-bar{display:flex;align-items:center;gap:10px;padding:8px 20px;background:#1a1d27;color:#fff;font-size:12px;font-weight:700;letter-spacing:.03em}
.lgc-back-bar a{color:#60a5fa;text-decoration:none;display:flex;align-items:center;gap:5px;transition:color var(--transition)}
.lgc-back-bar a:hover{color:#93c5fd}

/* ── NAV ── */
.nav{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:var(--nav-h);background:var(--nav-bg);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:300}
.nav-logo{font-family:'Nunito',sans-serif;font-size:1.5rem;font-weight:900;color:var(--acc);letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.nav-logo span{color:var(--txt);font-size:.75rem;font-weight:700;background:var(--s1);border:2px solid var(--border);border-radius:20px;padding:2px 10px;letter-spacing:.04em;text-transform:uppercase}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-stat{display:flex;align-items:center;gap:5px;font-weight:800;font-size:.95rem;color:var(--txt)}
.nav-stat svg{width:22px;height:22px}
.nav-hearts{display:flex;gap:2px}
.hrt{font-size:1.2rem;transition:all .35s}
.hrt.dead{filter:grayscale(1);opacity:.25;transform:scale(.75)}
.nav-tab-strip{display:flex;gap:2px}
.ntab{padding:8px 18px;border-radius:var(--r-sm);font-size:.82rem;font-weight:800;cursor:pointer;border:none;background:transparent;color:var(--txt2);transition:all var(--transition);letter-spacing:.04em;text-transform:uppercase}
.ntab.on{background:var(--acc-lt);color:var(--acc-dk)}
.ntab:hover:not(.on){background:var(--s1);color:var(--txt)}

/* ── SCREENS ── */
.scr{display:none}
.scr.on{display:block}

/* ═══════════════════════════════════════════════════
   DUOLINGO HOME — level sections + topic path
═══════════════════════════════════════════════════ */
#home{max-width:var(--path-w);margin:0 auto;padding:20px 16px 120px}

/* Section header (A1.1, A1.2, etc.) */
.dl-section{margin-bottom:8px}
.dl-section-hdr{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--acc);color:#fff;
  border-radius:var(--r);padding:16px 20px;
  margin-bottom:0;cursor:pointer;
  border-bottom:4px solid var(--acc-dk);
  transition:filter var(--transition);
  position:relative;
  user-select:none;
}
.dl-section-hdr:hover{filter:brightness(1.06)}
.dl-section-hdr.completed{background:#e5e5e5;border-bottom-color:#c5c5c5;color:#777}
.dl-section-hdr.active{background:var(--blue);border-bottom-color:var(--blue-dk)}
.dl-section-hdr.locked{background:#e5e5e5;border-bottom-color:#c5c5c5;color:#afafaf;cursor:default}
.dl-sec-left{}
.dl-sec-tag{font-size:.7rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin-bottom:3px;cursor:pointer}
.dl-sec-name{font-size:1.15rem;font-weight:900;letter-spacing:-.01em}
.dl-sec-sub{font-size:.78rem;opacity:.8;margin-top:3px}
.dl-sec-right{display:flex;align-items:center;gap:8px}
.dl-sec-badge{background:rgba(255,255,255,.25);border-radius:50px;padding:6px 14px;font-size:.78rem;font-weight:800;white-space:nowrap}
.dl-sec-lock{font-size:1.4rem}
.dl-sec-check{font-size:1.4rem}

/* See details toggle */
.dl-sec-details{display:none;background:rgba(0,0,0,.06);border-radius:0 0 var(--r) var(--r);overflow:hidden;margin-top:-4px}
.dl-sec-details.open{display:block}
.dl-sec-detail-inner{padding:12px 16px 8px}
.dl-sec-can{font-size:.82rem;font-style:italic;color:rgba(0,0,0,.55);padding:2px 0 8px}
.dl-see-btn{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:inherit;background:none;border:none;cursor:pointer;opacity:.75;display:flex;align-items:center;gap:4px;padding:0}
.dl-see-btn:hover{opacity:1}

/* Topic path (the winding nodes) */
.dl-path{padding:20px 0 12px;position:relative}
.dl-path-node{display:flex;flex-direction:column;align-items:center;margin-bottom:4px;position:relative}

/* Row of nodes — zigzag via margin */
.dl-row{display:flex;justify-content:center;margin:6px 0}
.dl-row.r-left {justify-content:flex-start;padding-left:80px}
.dl-row.r-right{justify-content:flex-end;padding-right:80px}
.dl-row.r-mid  {justify-content:center}

/* The circular node button */
.dl-node{
  width:72px;height:72px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;border:none;position:relative;
  transition:transform .15s,filter .15s;
  font-family:'Nunito',sans-serif;
  box-shadow:0 4px 0 rgba(0,0,0,.25);
  text-decoration:none;
}
.dl-node:hover{transform:translateY(-2px);filter:brightness(1.08)}
.dl-node:active{transform:translateY(2px);box-shadow:0 2px 0 rgba(0,0,0,.25)}
.dl-node.done{background:var(--acc);color:#fff}
.dl-node.active{background:var(--acc);color:#fff;animation:nodePulse 2s infinite}
.dl-node.locked{background:#e5e5e5;color:#afafaf;cursor:not-allowed;box-shadow:0 4px 0 #c5c5c5}
.dl-node.locked:hover{transform:none;filter:none}
.dl-node.chest{background:var(--gold);color:#7a5100;box-shadow:0 4px 0 #cc9800}
.dl-node.trophy{background:var(--gold);color:#7a5100;box-shadow:0 4px 0 #cc9800}

@keyframes nodePulse{0%,100%{box-shadow:0 4px 0 rgba(0,0,0,.25),0 0 0 0 rgba(88,204,2,.4)}50%{box-shadow:0 4px 0 rgba(0,0,0,.25),0 0 0 10px rgba(88,204,2,0)}}

.dl-node-icon{font-size:1.5rem;line-height:1}
.dl-node-lbl{font-size:.55rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;margin-top:2px;line-height:1;text-align:center;max-width:60px}

/* Start button (pops out below active node) */
.dl-start-wrap{display:flex;justify-content:center;margin:-2px 0 6px;position:relative;z-index:10}
.dl-start-btn{
  background:#fff;color:var(--acc-dk);
  border:2px solid var(--border);border-bottom:4px solid var(--border2);
  border-radius:var(--r-sm);padding:8px 20px;
  font-family:'Nunito',sans-serif;font-weight:900;font-size:.85rem;
  cursor:pointer;transition:all var(--transition);
  display:flex;align-items:center;gap:6px;
  box-shadow:0 2px 8px rgba(0,0,0,.1);
  letter-spacing:.03em;text-transform:uppercase;
}
.dl-start-btn:hover{background:var(--acc);color:#fff;border-color:var(--acc-dk);transform:translateY(-1px)}

/* Speech bubble on active */
.dl-bubble{
  background:#fff;border:2px solid var(--border);
  border-radius:var(--r);padding:10px 16px;
  font-size:.82rem;font-weight:700;color:var(--txt2);
  max-width:220px;text-align:center;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  position:relative;margin-bottom:6px;
}
.dl-bubble::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#fff}
.dl-bubble::before{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--border)}

/* Connector lines between nodes */
.dl-connector{width:4px;height:24px;background:var(--border2);border-radius:2px;margin:0 auto}
.dl-connector.done{background:var(--acc)}

/* ═══════════════════════════════════════════════════
   TOPIC POPUP / DRAWER
═══════════════════════════════════════════════════ */
.topic-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;animation:fadeOverlay .2s}
.topic-overlay.open{display:block}
@keyframes fadeOverlay{from{opacity:0}to{opacity:1}}
.topic-drawer{
  position:fixed;bottom:0;left:0;right:0;
  background:#fff;border-radius:24px 24px 0 0;
  padding:24px 24px 40px;z-index:401;
  animation:slideUp .25s cubic-bezier(.32,1,.32,1);
  max-height:85vh;overflow-y:auto;
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.drawer-handle{width:40px;height:4px;background:var(--border2);border-radius:2px;margin:0 auto 20px}
.drawer-title{font-size:1.25rem;font-weight:900;margin-bottom:4px}
.drawer-sub{font-size:.82rem;color:var(--txt2);margin-bottom:20px}
.drawer-close{position:absolute;top:18px;right:20px;width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:transparent;font-size:1rem;cursor:pointer;color:var(--txt2);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.drawer-close:hover{background:var(--s1);color:var(--txt)}
.story-list{}
.story-item{
  display:flex;align-items:center;gap:14px;
  padding:14px 0;border-bottom:2px solid var(--s1);
  cursor:pointer;transition:all var(--transition);
  border-radius:var(--r-sm);
}
.story-item:last-child{border-bottom:none}
.story-item:hover{background:var(--s1);padding-left:10px;padding-right:10px;margin:0 -10px}
.si-icon{width:52px;height:52px;border-radius:var(--r-sm);background:var(--s1);display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0;border:2px solid var(--border)}
.si-icon.done-icon{background:var(--acc-lt);border-color:var(--acc)}
.si-body{flex:1}
.si-title{font-weight:800;font-size:.95rem;margin-bottom:2px}
.si-meta{font-size:.76rem;color:var(--txt2)}
.si-check{color:var(--acc);font-size:1.3rem;flex-shrink:0}
.si-lock{color:var(--txt3);font-size:1.1rem;flex-shrink:0}
.drawer-start-btn{
  width:100%;margin-top:20px;
  background:var(--acc);color:#fff;
  border:none;border-bottom:4px solid var(--acc-dk);border-radius:var(--r);
  padding:16px;font-family:'Nunito',sans-serif;font-weight:900;font-size:1rem;
  cursor:pointer;transition:all var(--transition);letter-spacing:.03em;
}
.drawer-start-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.drawer-start-btn:active{transform:translateY(2px);border-bottom-width:2px}
.drawer-start-btn:disabled{background:#e5e5e5;color:#afafaf;border-bottom-color:#c5c5c5;cursor:not-allowed;transform:none}

/* ═══════════════════════════════════════════════════
   READING VIEW (unchanged layout, lighter theme)
═══════════════════════════════════════════════════ */
#reading{background:var(--bg)}
.r-top{margin-bottom:18px}
.r-back-btn{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:.85rem;color:var(--txt2);cursor:pointer;border:2px solid var(--border);background:#fff;border-radius:var(--r-sm);padding:6px 14px;margin-bottom:16px;transition:all var(--transition)}
.r-back-btn:hover{border-color:var(--acc);color:var(--acc)}
.r-chap{font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--acc-dk);margin-bottom:6px;display:flex;align-items:center;gap:7px}
.r-chap-badge{font-size:.65rem;padding:2px 9px;border-radius:20px;font-weight:900;color:#fff;background:var(--acc);letter-spacing:.06em}
.r-title{font-family:'Lora',serif;font-size:clamp(1.4rem,3vw,2rem);line-height:1.25;letter-spacing:-.01em;color:var(--txt)}
.r-prog-bar{height:8px;background:var(--s2);margin-bottom:22px;border-radius:4px;overflow:hidden;border:2px solid var(--border)}
.r-prog-fill{height:100%;background:var(--acc);border-radius:2px;transition:width .35s ease}

/* segment */
.seg-outer{margin-bottom:14px;border-radius:var(--r-sm);overflow:hidden;border:2px solid var(--border);transition:border-color .3s,box-shadow .3s;background:#fff}
.seg-outer.dim{opacity:.5}
.seg-outer.lit{border-color:var(--acc);box-shadow:0 0 0 2px var(--acc-lt)}
.seg{background:#fff;padding:20px 24px;font-family:'Lora',serif;font-size:1.05rem;line-height:2.15;border:none;border-radius:0;margin-bottom:0;color:var(--txt)}
.flip-bar{display:flex;border-top:2px solid var(--border);background:#fff}
.flip-btn{flex:1;padding:9px 0;font-size:.78rem;font-weight:900;font-family:'Nunito',sans-serif;cursor:pointer;border:none;transition:all var(--transition);letter-spacing:.06em;text-align:center;text-transform:uppercase}
.flip-btn-de{background:rgba(88,204,2,.06);color:var(--acc-dk)}.flip-btn-de.active{background:var(--acc);color:#fff}
.flip-btn-en{background:rgba(28,176,246,.06);color:var(--blue-dk)}.flip-btn-en.active{background:var(--blue);color:#fff}
.seg-de,.seg-en{transition:opacity .2s}
.seg-en{display:none;color:var(--blue-dk);font-style:italic;font-size:1rem;line-height:1.95}

/* audio bar */
.abar{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid var(--border);border-radius:50px;padding:8px 16px;margin-bottom:22px;position:sticky;top:68px;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.abtn{width:40px;height:40px;border-radius:50%;background:var(--acc);border:none;border-bottom:3px solid var(--acc-dk);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;flex-shrink:0;transition:all var(--transition)}
.abtn:hover{filter:brightness(1.1)}
.abtn:active{border-bottom-width:1px;transform:translateY(2px)}
.abtn.sec{background:var(--s1);color:var(--txt2);border-bottom-color:var(--border2)}.abtn.sec:hover{background:var(--s2)}
.ptrack{flex:1;height:8px;background:var(--s2);border-radius:4px;cursor:pointer;position:relative;border:2px solid var(--border)}
.pfill{height:100%;background:var(--acc);border-radius:2px;width:0%;pointer-events:none;transition:width .12s linear}
.phandle{position:absolute;top:50%;right:0;transform:translate(50%,-50%);width:14px;height:14px;background:#fff;border:3px solid var(--acc);border-radius:50%;pointer-events:none}
.spill{background:var(--s1);border:2px solid var(--border);color:var(--txt2);border-radius:20px;padding:4px 12px;font-size:.78rem;cursor:pointer;transition:all var(--transition);font-family:'Nunito',sans-serif;flex-shrink:0;font-weight:800}
.spill:hover{border-color:var(--acc);color:var(--acc-dk)}

/* words */
.w{display:inline;cursor:pointer;border-radius:3px;padding:1px 2px;transition:background .12s}
.w:hover{background:rgba(88,204,2,.2)}
.w.sp{color:var(--acc-dk);font-weight:700;border-bottom:2px solid var(--acc)}
.w.cur{background:rgba(88,204,2,.3);border-radius:4px}

/* tooltip */
.tip{position:fixed;z-index:9999;background:#fff;border:2px solid var(--acc);border-radius:var(--r);padding:18px 18px 14px;width:min(320px,94vw);box-shadow:0 8px 32px rgba(0,0,0,.15);pointer-events:all;display:none;animation:tipIn .22s cubic-bezier(.34,1.56,.64,1)}
@media(max-width:600px){.tip{position:fixed!important;bottom:0!important;top:auto!important;left:0!important;right:0!important;width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0;padding:20px 20px 36px;border:none;border-top:3px solid var(--acc);animation:tipSlideUp .24s ease}}
@keyframes tipIn{from{opacity:0;transform:scale(.88) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes tipSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.tip-handle{display:none;width:38px;height:4px;background:var(--border2);border-radius:2px;margin:0 auto 14px}
@media(max-width:600px){.tip-handle{display:block}}
.tip-word{font-family:'Lora',serif;font-size:1.4rem;color:var(--acc-dk);margin-bottom:3px}
.tip-en{font-size:.96rem;color:var(--txt);font-weight:800;margin-bottom:10px}
.tip-gr{font-size:.78rem;color:var(--txt2);padding:8px 11px;background:var(--s1);border-radius:var(--r-sm);margin-bottom:14px;line-height:1.75;border:1px solid var(--border)}
.tip-gr b{color:var(--blue-dk)}
.tip-acts{display:flex;gap:8px}
.tip-save{flex:1;padding:10px 8px;border-radius:var(--r-sm);border:2px solid var(--acc);background:transparent;color:var(--acc-dk);font-size:.85rem;cursor:pointer;font-family:'Nunito',sans-serif;font-weight:800;transition:all var(--transition)}
.tip-save:hover,.tip-save.sv{background:var(--acc);color:#fff}
.tip-x{width:42px;height:42px;border-radius:var(--r-sm);border:2px solid var(--border);background:transparent;color:var(--txt2);font-size:1rem;cursor:pointer;transition:all var(--transition);flex-shrink:0}
.tip-x:hover{border-color:var(--red);color:var(--red)}

/* quiz card */
.qcard{background:#fff;border:2px solid var(--border);border-radius:var(--r);padding:24px;margin:18px 0;animation:qIn .3s ease;box-shadow:0 2px 4px rgba(0,0,0,.06)}
@keyframes qIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.qbadge{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--acc-dk);font-weight:900;border:2px solid var(--acc-lt);border-radius:20px;padding:3px 11px;margin-bottom:13px;background:var(--acc-lt)}
.qq{font-family:'Lora',serif;font-size:1.1rem;margin-bottom:7px;line-height:1.6;color:var(--txt)}
.qsub{font-size:.84rem;color:var(--txt2);margin-bottom:18px}
.qfb{display:none;border-radius:var(--r-sm);padding:11px 14px;font-size:.88rem;font-weight:800;margin-bottom:12px;align-items:center;gap:8px}
.qfb.show{display:flex}
.qfb.ok{background:#d7f5b0;color:var(--acc-dk);border:2px solid var(--acc)}
.qfb.err{background:var(--red-lt);color:#c00;border:2px solid var(--red)}
.qacts{display:flex;gap:9px;justify-content:flex-end;margin-top:10px}
.qbtn{padding:10px 22px;border-radius:var(--r-sm);font-size:.85rem;font-family:'Nunito',sans-serif;font-weight:900;cursor:pointer;border:none;border-bottom:3px solid transparent;transition:all var(--transition);text-transform:uppercase;letter-spacing:.04em}
.qbtn-chk{background:var(--acc);color:#fff;border-bottom-color:var(--acc-dk)}.qbtn-chk:hover{filter:brightness(1.08)}
.qbtn-nxt{background:var(--blue);color:#fff;border-bottom-color:var(--blue-dk);display:none}.qbtn-nxt.on{display:block}.qbtn-nxt:hover{filter:brightness(1.08)}

/* fill tiles */
.fill-sentence{font-family:'Lora',serif;font-size:1.05rem;line-height:2.5;margin-bottom:18px;color:var(--txt)}
.blank-box{display:inline-flex;gap:4px;align-items:center;vertical-align:middle;flex-wrap:wrap;background:rgba(88,204,2,.07);border-radius:var(--r-sm);padding:3px 6px;min-width:60px;border:2px dashed var(--acc);cursor:pointer;transition:all var(--transition)}
.blank-box:hover{background:rgba(88,204,2,.14)}
.ltile{display:inline-flex;width:28px;height:32px;align-items:center;justify-content:center;background:var(--acc);color:#fff;border-radius:6px;font-weight:900;font-size:.95rem;font-family:'Nunito',sans-serif;cursor:pointer;transition:all .15s;user-select:none}
.ltile:hover{filter:brightness(1.1);transform:translateY(-2px)}
.ltile.used{opacity:.18;pointer-events:none}
.ltile.wrong-tile{background:var(--red);animation:shake .3s ease}
.letter-bank{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px;padding:12px;background:var(--s1);border-radius:var(--r-sm);min-height:48px;border:2px solid var(--border)}
.blank-placeholder{font-size:.85rem;color:var(--txt3);font-style:italic}

/* drag chips */
.wbank{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px;min-height:40px}
.wchip{background:#fff;border:2px solid var(--border);border-bottom:3px solid var(--border2);color:var(--txt);border-radius:var(--r-sm);padding:7px 13px;font-size:.88rem;cursor:pointer;transition:all var(--transition);user-select:none;font-weight:700}
.wchip:hover{border-color:var(--acc);color:var(--acc-dk);transform:translateY(-2px)}
.wchip.used{opacity:.2;pointer-events:none}
.dropz{min-height:50px;border:2px dashed var(--border2);border-radius:var(--r-sm);padding:9px 12px;display:flex;flex-wrap:wrap;gap:7px;align-items:center;transition:all var(--transition);margin-bottom:14px;background:var(--s1)}
.dropz.ov{border-color:var(--acc);background:rgba(88,204,2,.05)}
.dchip{background:var(--acc);color:#fff;border-radius:var(--r-sm);padding:7px 13px;font-size:.88rem;cursor:pointer;font-weight:800;transition:all var(--transition)}
.dchip:hover{background:var(--acc-dk)}
.dphint{color:var(--txt3);font-size:.85rem;font-style:italic}

/* match */
.match-wrap,.match-pairs-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.match-wrap{max-height:340px;overflow-y:auto}
.match-col{display:flex;flex-direction:column;gap:6px}
.mi{padding:10px 12px;border-radius:var(--r-sm);border:2px solid var(--border);cursor:pointer;transition:all .2s;font-size:.88rem;text-align:center;background:#fff;user-select:none;line-height:1.3;min-height:40px;display:flex;align-items:center;justify-content:center;font-weight:700}
.mi:hover{border-color:var(--acc);background:rgba(88,204,2,.06)}
.mi.sel{border-color:var(--acc);background:rgba(88,204,2,.18);color:var(--acc-dk);font-weight:900;transform:scale(1.03)}
.mi.paired-ok{border-color:var(--acc);background:var(--acc-lt);color:var(--acc-dk);pointer-events:none;font-weight:800}
.mi.paired-err{border-color:var(--red);background:var(--red-lt);color:#c00;animation:shake .35s ease}
.mi.fading{opacity:0;transform:scale(.82);transition:all .4s ease;pointer-events:none}
.mi.sliding-in{animation:slideInPair .35s ease}
.mi.mi-ghost{border-color:transparent;background:transparent;pointer-events:none}
.match-counter{font-size:.8rem;color:var(--txt2);margin-bottom:10px;text-align:center;font-weight:700}

/* MCQ */
.mcq-prog{display:flex;gap:4px;margin-bottom:16px}
.mcq-pip{flex:1;height:6px;border-radius:3px;background:var(--s2);transition:background .3s}
.mcq-pip.done{background:var(--acc)}
.mcq-pip.active{background:var(--acc)}
.mcq-word{font-family:'Lora',serif;font-size:2rem;color:var(--acc-dk);text-align:center;margin:10px 0 4px}
.mcq-hint{font-size:.78rem;color:var(--txt2);text-align:center;margin-bottom:20px;font-style:italic}
.mcq-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
.mcq-opt{padding:14px 10px;border-radius:var(--r-sm);border:2px solid var(--border);border-bottom:3px solid var(--border2);background:#fff;color:var(--txt);font-size:.9rem;font-family:'Nunito',sans-serif;font-weight:700;cursor:pointer;transition:all var(--transition);text-align:center;line-height:1.35}
.mcq-opt:hover:not(:disabled){border-color:var(--acc);background:rgba(88,204,2,.08);color:var(--acc-dk)}
.mcq-opt:disabled{cursor:default}
.mcq-opt.mcq-correct{border-color:var(--acc);background:var(--acc-lt);color:var(--acc-dk);font-weight:900}
.mcq-opt.mcq-wrong{border-color:var(--red);background:var(--red-lt);color:#c00;font-weight:900}

/* fill updates */
.lbank-wrap{margin-bottom:16px}
.lbank-label{font-size:.73rem;color:var(--txt2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.typed-tile{display:inline-flex;width:24px;height:28px;align-items:center;justify-content:center;background:var(--acc);color:#fff;border-radius:5px;font-weight:900;font-size:.9rem;margin:1px}

/* done banner */
.done-banner{display:none;background:#fff;border:2px solid var(--acc);border-radius:var(--r);padding:32px;text-align:center;margin-top:28px;animation:qIn .4s ease;box-shadow:0 4px 24px rgba(88,204,2,.15)}
.done-banner.show{display:block}
.db-icon{font-size:3.5rem;margin-bottom:12px}
.db-title{font-family:'Lora',serif;font-size:1.7rem;margin-bottom:8px;color:var(--acc-dk)}
.db-sub{color:var(--txt2);margin-bottom:22px;font-size:.95rem}
.db-acts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.dbtn{padding:12px 28px;border-radius:var(--r-sm);font-size:.9rem;font-family:'Nunito',sans-serif;font-weight:900;cursor:pointer;border:none;border-bottom:3px solid transparent;transition:all var(--transition);text-transform:uppercase;letter-spacing:.04em}
.dbtn-p{background:var(--acc);color:#fff;border-bottom-color:var(--acc-dk)}.dbtn-p:hover{filter:brightness(1.08);transform:translateY(-1px)}
.dbtn-o{background:transparent;color:var(--txt2);border:2px solid var(--border)}.dbtn-o:hover{border-color:var(--txt)}

/* game over */
#gover{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:500;align-items:center;justify-content:center}
#gover.show{display:flex}
.go-box{background:#fff;border:2px solid var(--red);border-radius:var(--r);padding:44px 32px;text-align:center;max-width:380px;width:90%;animation:qIn .4s ease;box-shadow:0 12px 48px rgba(255,75,75,.2)}
.go-t{font-family:'Lora',serif;font-size:1.8rem;color:var(--red);margin-bottom:8px}
.go-s{color:var(--txt2);margin-bottom:26px;font-size:.93rem}

/* vocab page */
#vocab{max-width:760px;margin:0 auto;padding:36px 18px 100px}
.vh{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:10px}
.vh h2{font-size:1.7rem;font-weight:900;color:var(--txt)}
.varow{display:flex;gap:8px}
.vbtn{padding:8px 18px;border-radius:var(--r-sm);font-size:.82rem;font-family:'Nunito',sans-serif;font-weight:900;cursor:pointer;border:2px solid transparent;border-bottom:3px solid transparent;transition:all var(--transition);text-transform:uppercase;letter-spacing:.04em}
.vbp{background:var(--acc);color:#fff;border-bottom-color:var(--acc-dk)}.vbp:hover{filter:brightness(1.08)}
.vbo{background:transparent;color:var(--txt2);border-color:var(--border);border-bottom-color:var(--border2)}.vbo:hover{border-color:var(--acc);color:var(--acc-dk)}
.vempty{text-align:center;padding:72px 20px;color:var(--txt2)}
.vempty .ei{font-size:4rem;margin-bottom:14px}
.vlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-bottom:32px}
.vc{background:#fff;border:2px solid var(--border);border-radius:var(--r-sm);padding:14px;position:relative;transition:all var(--transition)}
.vc:hover{border-color:var(--acc);transform:translateY(-2px)}
.vc-w{font-family:'Lora',serif;font-size:1.1rem;color:var(--acc-dk);margin-bottom:3px}
.vc-e{font-size:.88rem;color:var(--txt);font-weight:700;margin-bottom:5px}
.vc-g{font-size:.75rem;color:var(--txt2);line-height:1.55}
.vc-del{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:5px;border:none;background:transparent;color:var(--txt3);cursor:pointer;font-size:.8rem;transition:all var(--transition)}
.vc-del:hover{background:var(--red-lt);color:var(--red)}
.vc-mbar{height:4px;border-radius:2px;margin-top:9px;background:var(--s2);overflow:hidden}
.vc-mfill{height:100%;border-radius:2px;background:var(--acc);transition:width .4s}

/* practice */
.prac-sec{border-top:2px solid var(--border);padding-top:32px}
.prac-sec h3{font-size:1.3rem;font-weight:900;margin-bottom:7px}
.prac-desc{color:var(--txt2);font-size:.88rem;margin-bottom:22px}
.ppbar{height:8px;background:var(--s2);border-radius:4px;margin-bottom:18px;overflow:hidden;border:2px solid var(--border)}
.ppfill{height:100%;background:var(--acc);border-radius:2px;transition:width .4s}
.pstats{display:flex;gap:24px;justify-content:center;margin-bottom:20px}
.pst{text-align:center}
.pst-v{font-size:1.5rem;font-weight:900}
.pst-l{font-size:.72rem;color:var(--txt2);text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.fcard{background:#fff;border:2px solid var(--border);border-bottom:4px solid var(--border2);border-radius:var(--r);min-height:200px;cursor:pointer;perspective:1000px;margin-bottom:18px;position:relative;transition:all var(--transition)}
.fcard:hover{border-color:var(--acc);transform:translateY(-2px)}
.fci{width:100%;height:100%;min-height:200px;transition:transform .48s;transform-style:preserve-3d;position:relative}
.fcard.flip .fci{transform:rotateY(180deg)}
.fc-f,.fc-b{position:absolute;inset:0;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;border-radius:var(--r)}
.fc-b{transform:rotateY(180deg);background:#fff}
.fc-lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--txt3);margin-bottom:12px;font-weight:800}
.fc-dw{font-family:'Lora',serif;font-size:2rem;color:var(--acc-dk)}
.fc-ew{font-size:1.2rem;color:var(--txt);font-weight:800;margin-bottom:6px}
.fc-gr{font-size:.82rem;color:var(--txt2);max-width:250px;line-height:1.65}
.fc-hint{font-size:.8rem;color:var(--txt3);margin-top:8px}
.pctrls{display:flex;gap:10px;justify-content:center;margin-top:4px}
.pc{padding:11px 26px;border-radius:var(--r-sm);font-size:.88rem;font-family:'Nunito',sans-serif;font-weight:900;cursor:pointer;border:2px solid;border-bottom:3px solid;transition:all var(--transition);text-transform:uppercase}
.pc-w{background:var(--red-lt);color:#c00;border-color:var(--red);border-bottom-color:#c00}.pc-w:hover{background:#ffc5c5}
.pc-r{background:var(--acc-lt);color:var(--acc-dk);border-color:var(--acc);border-bottom-color:var(--acc-dk)}.pc-r:hover{background:#c8f090}
/* Flashcard flip WebKit fix */
.fc-f,.fc-b{-webkit-backface-visibility:hidden;backface-visibility:hidden}
.fci{-webkit-transform-style:preserve-3d;transform-style:preserve-3d}
.fcard.flip .fci{-webkit-transform:rotateY(180deg);transform:rotateY(180deg)}
/* Pronunciation button */
.fc-speak{background:none;border:none;font-size:1.05rem;cursor:pointer;padding:4px 8px;border-radius:20px;color:var(--txt3);transition:all .15s;margin-top:8px;line-height:1;display:inline-flex;align-items:center;gap:4px;font-family:'Nunito',sans-serif;font-weight:700;font-size:.82rem}
.fc-speak:hover{background:var(--s2);color:var(--acc-dk)}
.fc-speak:active{transform:scale(.95)}
/* Match test */
.match-item{padding:10px 12px;border:2px solid var(--border);border-radius:var(--r-sm);font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s;background:#fff;color:var(--txt);text-align:center;line-height:1.3}
.match-item:hover{border-color:var(--acc);color:var(--acc-dk)}
.match-item.match-sel{border-color:var(--acc);background:var(--acc-lt);color:var(--acc-dk)}
.match-item.match-done{border-color:var(--acc);background:var(--acc-lt);color:var(--acc-dk);cursor:default;opacity:.6;pointer-events:none}
.match-item.match-wrong{border-color:var(--red);background:#ffe5e5;color:#c00}
/* Article test */
.art-btn:hover:not(:disabled){border-color:var(--acc)!important;color:var(--acc-dk)!important;transform:translateY(-2px)}
.art-btn:active:not(:disabled){transform:translateY(1px)}
.sdone{display:none;text-align:center;padding:40px 20px;background:#fff;border-radius:var(--r);border:2px solid var(--acc)}
.sdone.show{display:block}
.ptabs{display:flex;gap:6px;margin-bottom:22px;flex-wrap:wrap}
.ptab{padding:8px 16px;border-radius:var(--r-sm);font-size:.82rem;font-weight:900;cursor:pointer;border:2px solid var(--border);border-bottom:3px solid var(--border2);background:#fff;color:var(--txt2);transition:all var(--transition);font-family:'Nunito',sans-serif;text-transform:uppercase}
.ptab.on{background:var(--acc);color:#fff;border-color:var(--acc);border-bottom-color:var(--acc-dk)}
.ptab:hover:not(.on){border-color:var(--acc);color:var(--acc-dk)}

/* chapter quiz banner */
.chapter-quiz-wrap{background:#fff;border:2px solid var(--border);border-radius:var(--r);padding:26px;margin-top:30px;animation:qIn .4s ease}
.cq-title{font-family:'Lora',serif;font-size:1.3rem;margin-bottom:6px;color:var(--acc-dk)}
.cq-sub{color:var(--txt2);font-size:.88rem;margin-bottom:20px}
.cq-prog-bar{height:8px;background:var(--s2);border-radius:4px;margin-bottom:16px;overflow:hidden;border:2px solid var(--border)}
.cq-prog-fill{height:100%;background:var(--acc);border-radius:2px;transition:width .4s}
.cq-stats{display:flex;gap:20px;margin-bottom:16px}
.cq-stat{text-align:center}
.cq-stat-v{font-size:1.3rem;font-weight:900}
.cq-stat-l{font-size:.7rem;color:var(--txt2);text-transform:uppercase;letter-spacing:.1em;font-weight:800}

/* vocab MCQ */
.vmcq-card{background:#fff;border:2px solid var(--border);border-radius:var(--r-sm);padding:22px;margin-bottom:14px;animation:qIn .3s ease}
.vmcq-word{font-family:'Lora',serif;font-size:1.8rem;color:var(--acc-dk);text-align:center;margin:10px 0 4px}
.vmcq-sub{font-size:.78rem;color:var(--txt2);text-align:center;margin-bottom:18px;font-style:italic}
.vmcq-opts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.vmcq-opt{padding:12px 10px;border-radius:var(--r-sm);border:2px solid var(--border);border-bottom:3px solid var(--border2);background:#fff;color:var(--txt);font-size:.88rem;font-family:'Nunito',sans-serif;font-weight:700;cursor:pointer;transition:all var(--transition);text-align:center}
.vmcq-opt:hover:not(:disabled){border-color:var(--acc);background:rgba(88,204,2,.07)}
.vmcq-opt:disabled{cursor:default}
.vmcq-opt.v-correct{border-color:var(--acc)!important;background:var(--acc-lt)!important;color:var(--acc-dk)!important;font-weight:900}
.vmcq-opt.v-wrong{border-color:var(--red)!important;background:var(--red-lt)!important;color:#c00!important;font-weight:900}
.vmcq-prog{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap}
.vmcq-pip{flex:1;height:6px;border-radius:3px;background:var(--s2);transition:background .3s;flex-shrink:0}
.vmcq-pip.done-ok{background:var(--acc)}
.vmcq-pip.done-err{background:var(--red)}
.vmcq-pip.cur{background:var(--acc)}

/* write */
.write-input{width:100%;padding:12px 14px;border-radius:var(--r-sm);border:2px solid var(--border);background:#fff;color:var(--txt);font-size:1rem;font-family:'Nunito',sans-serif;resize:vertical;box-sizing:border-box;margin:12px 0 6px;transition:border-color var(--transition)}
.write-input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(88,204,2,.15)}
.write-input:disabled{opacity:.7}
.wa-others{margin-top:10px;padding:10px 12px;background:var(--s1);border-radius:var(--r-sm);border:1px solid var(--border)}
.wa-label{font-size:.72rem;color:var(--txt2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;font-weight:800}
.wa-chip{display:inline-block;background:#fff;border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:.82rem;margin:3px 4px 3px 0;color:var(--txt)}
.qq-hint{font-size:.82rem;color:var(--blue-dk);background:rgba(28,176,246,.08);border-radius:var(--r-sm);padding:6px 10px;margin-bottom:10px;border-left:3px solid var(--blue)}

/* gender */
.gender-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px;min-height:44px;padding:8px;background:var(--s1);border-radius:var(--r-sm);border:2px solid var(--border)}
.gender-chip{padding:8px 16px;border-radius:20px;border:2px solid var(--acc);background:#fff;color:var(--acc-dk);font-weight:900;cursor:grab;user-select:none;transition:all var(--transition);font-size:.92rem}
.gender-chip:hover{background:rgba(88,204,2,.1);transform:scale(1.05)}
.gender-chip.sel{background:var(--acc);color:#fff;transform:scale(1.08)}
.gender-chip.placed{opacity:.3;cursor:default;border-style:dashed}
.gender-chip.correct-placed{border-color:var(--acc);color:var(--acc-dk);opacity:1}
.gender-chip.wrong-placed{border-color:var(--red);color:#c00;opacity:1}
.gender-drums{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
@media(min-width:600px){.gender-drums{grid-template-columns:repeat(4,1fr)}}
.gender-drum{border:2px solid;border-radius:var(--r-sm);overflow:hidden;min-height:100px;cursor:pointer;transition:all var(--transition)}
.gender-drum.gdrum-hover{transform:scale(1.03)}
.gdrum-header{padding:8px 0;text-align:center;font-size:1.2rem;font-weight:900}
.gdrum-sub{font-size:.68rem;color:var(--txt2);text-align:center;padding:4px 0;text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.gdrum-items{padding:6px;display:flex;flex-wrap:wrap;gap:4px;min-height:36px}
.gdrum-item{padding:3px 10px;border-radius:20px;background:var(--s1);border:1px solid var(--border);font-size:.8rem;cursor:pointer;transition:all .15s}
.gdrum-item:hover{border-color:var(--red)}

/* dialogue */
.dlg-line{display:flex;align-items:flex-start;gap:10px;margin:10px 0;line-height:1.65}
.dlg-speaker{flex-shrink:0;font-weight:900;font-size:.75rem;letter-spacing:.04em;text-transform:uppercase;border:2px solid;border-radius:20px;padding:2px 10px;margin-top:2px;white-space:nowrap;min-width:62px;text-align:center}
.dlg-text{flex:1;font-size:1rem;color:var(--txt)}
.dlg-text .w{display:inline}

/* comprehension */
.q-comprehension-q{font-size:1.05rem;font-weight:700;color:var(--txt);margin:10px 0 4px}
.q-comprehension-hint{font-size:.82rem;color:var(--txt2);margin-bottom:12px;font-style:italic}
.q-comprehension-sentence{line-height:1.85}
.qbtn-check{display:block;margin:14px auto 0;background:var(--acc);color:#fff;border:none;border-bottom:3px solid var(--acc-dk);border-radius:var(--r-sm);padding:9px 28px;font-size:.9rem;font-weight:900;cursor:pointer;transition:all var(--transition);text-transform:uppercase}
.qbtn-check:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* admin */
.dg-seg-preview{background:#f0f0f1;border-left:3px solid #0073aa;padding:8px 12px;margin:0 0 16px;font-size:13px;border-radius:0 4px 4px 0}
.dg-qtype-legend{background:#fff;border:1px solid #ddd;border-radius:4px;padding:12px 16px;margin-bottom:16px;font-size:13px;line-height:2}
.dg-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;text-transform:uppercase;margin:0 2px}
.dg-badge-match{background:#e5f5e5;color:#1a7f37}.dg-badge-mcq{background:#fff3cd;color:#856404}.dg-badge-fill{background:#e3f0fb;color:#0550ae}.dg-badge-drag{background:#fde8e8;color:#b91c1c}.dg-badge-write{background:#f3e8ff;color:#6b21a8}.dg-badge-gender{background:#e0f2fe;color:#075985}

/* animations */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.shake{animation:shake .35s ease}
@keyframes hpop{0%{transform:scale(1)}40%{transform:scale(1.45)}100%{transform:scale(.8);opacity:.25}}
.hpop{animation:hpop .45s ease forwards}
@keyframes pairPop{0%{transform:scale(1)}50%{transform:scale(1.09)}100%{transform:scale(1)}}
@keyframes slideInPair{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* responsive */
@media(max-width:640px){
  .nav{padding:0 14px}.nav-logo{font-size:1.2rem}
  #home{padding:14px 12px 100px}
  .dl-section-hdr{padding:14px 16px}
  .dl-sec-name{font-size:1rem}
  .dl-node{width:60px;height:60px}
  .dl-node-icon{font-size:1.2rem}
  .seg{padding:16px 14px;font-size:.97rem}
  .qcard{padding:16px 14px}
  .mcq-opts{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════════
   UNIT HUB SCREEN
═══════════════════════════════════════════════════ */
.hub-header{display:flex;align-items:center;gap:16px;margin-bottom:8px;padding:20px;background:#fff;border-radius:var(--r);border:2px solid var(--border)}
.hub-emoji{font-size:3rem;flex-shrink:0;line-height:1}
.hub-info{flex:1}
.hub-breadcrumb{font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;color:var(--txt2);margin-bottom:4px}
.hub-title{font-family:'Lora',serif;font-size:1.5rem;font-weight:700;color:var(--txt);margin-bottom:2px;line-height:1.2}
.hub-subtitle{font-size:.88rem;color:var(--txt2);font-weight:600}
.hub-word-count{font-size:.82rem;color:var(--txt2);font-weight:700;text-align:center;padding:8px 0 16px;letter-spacing:.04em;text-transform:uppercase}

/* 2-column tile grid */
.hub-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hub-tile{
  border-radius:var(--r);padding:22px 16px;
  cursor:pointer;transition:all var(--transition);
  border-bottom-width:4px!important;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;
  min-height:130px;justify-content:center;
  box-shadow:0 2px 4px rgba(0,0,0,.06);
  position:relative;overflow:hidden;
  background-color:transparent;outline:none;
  -webkit-appearance:none;appearance:none;
}
button.hub-tile{border-style:solid;}
.hub-tile:hover:not(.hub-tile-locked){transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.hub-tile:active:not(.hub-tile-locked){transform:translateY(1px);box-shadow:0 1px 4px rgba(0,0,0,.1)}
.hub-tile-locked{cursor:not-allowed;opacity:.65}
.hub-tile-icon{font-size:2rem;line-height:1;margin-bottom:2px}
.hub-tile-label{font-size:.95rem;font-weight:900;letter-spacing:.01em}
.hub-tile-desc{font-size:.72rem;line-height:1.4;max-width:140px}

/* Story tile — full width */
.hub-tile.hub-tile-story,.hub-tile.hub-tile-conv{grid-column:span 1}

/* Make story + conv tiles span full row when both present */
.hub-grid .hub-tile:nth-child(5),
.hub-grid .hub-tile:nth-child(6){
  /* keep 2-col layout — they sit side by side in the grid naturally */
}

/* ══════════════════════════════════════════════════════════════
   AUFGABEN (STUDENT QUESTIONS) SCREEN
══════════════════════════════════════════════════════════════ */

/* German special character keyboard buttons */
.aufg-spchar {
  background: #fff;
  border: 2px solid #ce93d8;
  border-radius: 7px;
  padding: 5px 11px;
  font-size: 16px;
  font-weight: 800;
  color: #6a1b9a;
  cursor: pointer;
  min-width: 38px;
  transition: background .15s, transform .1s;
  font-family: 'Nunito', sans-serif;
}
.aufg-spchar:hover { background: #ede7f6; transform: scale(1.08); }
.aufg-spchar:active { transform: scale(.95); }

/* Question card */
.aufg-card {
  background: #fff;
  border: 2px solid #e1bee7;
  border-radius: 14px;
  padding: 22px 20px 18px;
  margin-bottom: 22px;
  box-shadow: 0 2px 10px rgba(123,31,162,.08);
}
.aufg-card-num {
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #ab47bc;
  margin-bottom: 6px;
}
.aufg-card-badge {
  display: inline-block;
  background: #f3e5f5;
  color: #6a1b9a;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 9px;
  border-radius: 20px;
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.aufg-card-img {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border-radius: 10px;
  margin-bottom: 14px;
}
.aufg-prompt {
  font-family: 'Lora', serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--txt);
  margin-bottom: 14px;
  line-height: 1.5;
}
/* Text input fields for answers */
.aufg-input {
  width: 100%;
  padding: 10px 14px;
  border: 2px solid #e1bee7;
  border-radius: 9px;
  font-size: 1rem;
  font-family: 'Nunito', sans-serif;
  color: var(--txt);
  background: #fdf6ff;
  transition: border .2s;
  box-sizing: border-box;
  margin-bottom: 8px;
}
.aufg-input:focus { outline: none; border-color: #ab47bc; background: #fff; }
.aufg-input.correct { border-color: #4caf50; background: #f1f8f1; }
.aufg-input.incorrect { border-color: #f44336; background: #fff8f8; }

/* MCQ option buttons */
.aufg-mcq-opts { display: flex; flex-direction: column; gap: 10px; }
.aufg-opt {
  padding: 12px 16px;
  border: 2px solid #e1bee7;
  border-radius: 10px;
  cursor: pointer;
  font-size: .97rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 600;
  color: var(--txt);
  background: #fff;
  text-align: left;
  transition: all .15s;
}
.aufg-opt:hover:not(:disabled) { background: #f3e5f5; border-color: #ab47bc; }
.aufg-opt.selected { background: #ede7f6; border-color: #7b1fa2; color: #4a148c; }
.aufg-opt.correct  { background: #e8f5e9; border-color: #4caf50; color: #1b5e20; }
.aufg-opt.wrong    { background: #ffebee; border-color: #f44336; color: #b71c1c; }

/* Fill blank */
.aufg-blank-wrap { position: relative; }
.aufg-blank-inline {
  display: inline-block;
  min-width: 120px;
  padding: 3px 10px;
  border-bottom: 3px solid #ab47bc;
  background: #fdf6ff;
  border-radius: 4px 4px 0 0;
  font-size: 1rem;
  font-family: 'Nunito', sans-serif;
  font-weight: 700;
  color: #4a148c;
  text-align: center;
  cursor: text;
}

/* Match column layout */
.aufg-match-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 8px;
}
.aufg-match-item {
  padding: 10px 14px;
  border: 2px solid #e1bee7;
  border-radius: 9px;
  font-size: .94rem;
  font-weight: 700;
  cursor: pointer;
  background: #fff;
  transition: all .15s;
  text-align: center;
}
.aufg-match-item:hover:not(.matched):not(.used) { background: #f3e5f5; border-color: #ab47bc; }
.aufg-match-item.selected { background: #ede7f6; border-color: #7b1fa2; color: #4a148c; }
.aufg-match-item.matched  { background: #e8f5e9; border-color: #4caf50; color: #1b5e20; cursor: default; }
.aufg-match-item.wrong    { background: #ffebee; border-color: #f44336; animation: aufg-shake .3s; }
.aufg-match-col { display: flex; flex-direction: column; gap: 8px; }

@keyframes aufg-shake {
  0%,100%{transform:translateX(0)} 25%{transform:translateX(-5px)} 75%{transform:translateX(5px)}
}

/* Media player for audio/video */
.aufg-media-wrap {
  background: #1a1d27;
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 14px;
}
.aufg-audio-player {
  width: 100%;
  margin-bottom: 10px;
}
.aufg-video-embed {
  width: 100%;
  aspect-ratio: 16/9;
  border: none;
  border-radius: 8px;
  margin-bottom: 10px;
}

/* Submit / check button */
.aufg-check-btn {
  width: 100%;
  padding: 13px;
  background: linear-gradient(135deg,#ab47bc,#7b1fa2);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 800;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
  margin-top: 12px;
  transition: opacity .2s, transform .1s;
  letter-spacing: .03em;
}
.aufg-check-btn:hover { opacity: .92; transform: translateY(-1px); }
.aufg-check-btn:active { transform: translateY(0); }
.aufg-check-btn:disabled { background: #ccc; cursor: default; transform: none; opacity: 1; }

/* Feedback inline messages */
.aufg-feedback {
  margin-top: 10px;
  padding: 9px 14px;
  border-radius: 8px;
  font-size: .92rem;
  font-weight: 700;
  display: none;
}
.aufg-feedback.correct  { background: #e8f5e9; color: #1b5e20; border: 1px solid #a5d6a7; display: block; }
.aufg-feedback.incorrect{ background: #ffebee; color: #b71c1c; border: 1px solid #ef9a9a; display: block; }

/* Sub-questions list */
.aufg-subqs { margin-top: 12px; }
.aufg-subq {
  margin-bottom: 12px;
}
.aufg-subq-label {
  font-size: .88rem;
  font-weight: 700;
  color: #7b1fa2;
  margin-bottom: 5px;
}

/* Nav row between questions */
.aufg-nav {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-top: 18px;
}

/* ═══════════════════════════════════════════════════
   UNIVERSAL GERMAN KEYBOARD  #lgc-unikb
═══════════════════════════════════════════════════ */
#lgc-unikb {
  display: none;           /* shown by JS on input focus */
  position: absolute;
  z-index: 99999;
  align-items: center;
  gap: 5px;
  background: linear-gradient(135deg, #e8f5e9, #f1f8e9);
  border: 1.5px solid #81c784;
  border-radius: 10px;
  padding: 6px 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
  flex-wrap: wrap;
  max-width: 310px;
  pointer-events: auto;
}
.unikb-lbl {
  font-size: 10px;
  font-weight: 900;
  color: #388e3c;
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
  margin-right: 2px;
  user-select: none;
}
.unikb-btn {
  background: #fff;
  border: 1.5px solid #a5d6a7;
  border-bottom: 3px solid #66bb6a;
  border-radius: 7px;
  padding: 5px 10px;
  font-size: 1.05rem;
  font-weight: 700;
  font-family: 'Nunito', sans-serif;
  color: #2e7d32;
  cursor: pointer;
  transition: background .12s, transform .1s;
  user-select: none;
  min-width: 36px;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}
.unikb-btn:hover {
  background: #e8f5e9;
}
.unikb-btn:active {
  transform: translateY(2px);
  border-bottom-width: 1px;
}

/* Hub banner image toggle area */
#hub-banner img {
  display: block;
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 12px;
}

/* ── Skip-to-next-paragraph button ────────────────────── */
.skip-btn {
  font-size: .7rem !important;
  padding: 0 8px !important;
  min-width: 36px;
  letter-spacing: -.5px;
  opacity: .75;
  flex-shrink: 0;
}
.skip-btn:hover { opacity: 1; }

/* ── Conv skip / weiter button inside segment ─────────── */
.conv-skip-btn {
  display: block;
  margin: 10px auto 4px;
  background: var(--acc);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 22px;
  font-size: .88rem;
  font-weight: 800;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
  transition: opacity .15s;
}
.conv-skip-btn:hover { opacity: .88; }

/* ── Per-segment optional image zone ──────────────────── */
.seg-img-zone {
  padding: 6px 16px 10px;
  background: transparent;
}
.seg-img-add {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border: 1.5px dashed #ccc;
  border-radius: 8px;
  cursor: pointer;
  font-size: .8rem;
  color: #888;
  font-family: 'Nunito', sans-serif;
  transition: border-color .15s, color .15s;
  user-select: none;
}
.seg-img-add:hover { border-color: var(--acc); color: var(--acc); }
.seg-img-add-icon { font-size: 1rem; }
.seg-img-add-label { font-weight: 700; }
.seg-img-wrap {
  position: relative;
  display: inline-block;
  max-width: 100%;
}
.seg-img-preview {
  max-width: 100%;
  max-height: 220px;
  border-radius: 10px;
  display: block;
  border: 2px solid var(--border);
  object-fit: cover;
}
.seg-img-remove {
  position: absolute;
  top: 4px; right: 4px;
  background: rgba(0,0,0,.55);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 22px; height: 22px;
  font-size: .75rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
  transition: background .15s;
}
.seg-img-remove:hover { background: rgba(200,0,0,.8); }

/* ── Hub tile group (accordion for multiple stories/convs) ── */
.hub-tile-group {
  margin-bottom: 0;
}
.hub-tile-group-header {
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.hub-tile-group-header:hover {
  filter: brightness(.97);
}
.hub-tile-sub {
  border-radius: 10px !important;
}

/* ── Story Weiter button (no-questions segments) ──────── */
.story-weiter-btn {
  display: inline-block;
  background: var(--acc);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 9px 26px;
  font-size: .9rem;
  font-weight: 800;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
  transition: opacity .15s;
}
.story-weiter-btn:hover { opacity: .88; }

/* ── Segment image (frontend read-only) ── */
.seg-img-zone {
  padding: 0 16px 14px;
  text-align: center; /* default: centred */
}
/* Alignment variants */
.seg-img-align-left   { text-align: left; }
.seg-img-align-center { text-align: center; }
.seg-img-align-right  { text-align: right; }
.seg-img-align-full   { text-align: center; padding-left: 0; padding-right: 0; }

.seg-img-preview {
  display: inline-block;
  max-width: 100%;
  max-height: 300px;
  border-radius: 12px;
  border: 1.5px solid var(--border);
  object-fit: cover;
  box-shadow: 0 2px 12px rgba(0,0,0,.10);
}
.seg-img-align-full .seg-img-preview {
  width: 100%;
  max-height: 360px;
  border-radius: 10px;
}
/* Left/right: float with text wrap */
.seg-img-align-left .seg-img-preview {
  max-width: 50%;
  float: left;
  margin: 0 16px 10px 0;
  border-radius: 10px;
}
.seg-img-align-right .seg-img-preview {
  max-width: 50%;
  float: right;
  margin: 0 0 10px 16px;
  border-radius: 10px;
}
/* Clear floats after float images */
.seg-img-align-left::after,
.seg-img-align-right::after {
  content: '';
  display: table;
  clear: both;
}

/* ═══════════════════════════════════════════════════════
   v35 ADDITIONS
   ═══════════════════════════════════════════════════════ */

/* ── Path node: image icon ─────────────────────────────── */
.dl-node-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
  pointer-events: none;
}
.dl-node-icon img.dl-node-img {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  object-fit: cover;
}
@media(max-width:480px){
  .dl-node-icon img.dl-node-img { width: 30px; height: 30px; }
}

/* ── Chapter cover card ────────────────────────────────── */
.chapter-cover-card {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 24px;
  background: linear-gradient(135deg, #1a1d27 0%, #24283a 100%);
  border: 2px solid rgba(255,255,255,.08);
  box-shadow: 0 8px 32px rgba(0,0,0,.22);
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  user-select: none;
}
.chapter-cover-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 40px rgba(0,0,0,.28);
}
.chapter-cover-card:hover .chap-cover-preview {
  max-height: 220px;
  opacity: 1;
  padding-top: 10px;
}
.chap-cover-inner {
  padding: 32px 28px 20px;
  text-align: center;
}
.chap-cover-emoji {
  font-size: 3.5rem;
  line-height: 1;
  margin-bottom: 12px;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.3));
}
.chap-cover-img {
  width: 100%;
  height: 140px;
  background-size: cover;
  background-position: center;
  margin-bottom: 12px;
  border-radius: 12px;
}
.chap-cover-title {
  font-family: 'Lora', serif;
  font-size: 1.7rem;
  font-weight: 700;
  color: #f5f5f5;
  letter-spacing: .01em;
  margin-bottom: 8px;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
}
.chap-cover-level {
  display: inline-block;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  border-radius: 20px;
  padding: 3px 12px;
  margin-bottom: 10px;
}
.chap-cover-hint {
  font-size: .73rem;
  color: rgba(255,255,255,.35);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 700;
  margin-top: 4px;
}
.chap-cover-preview {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .35s ease, opacity .3s ease, padding-top .3s ease;
  text-align: left;
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 0 4px;
}
.chap-preview-line {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  line-height: 1.6;
  padding: 3px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.chap-preview-line:last-child { border-bottom: none; }
.chap-cover-btn {
  display: block;
  width: calc(100% - 48px);
  margin: 0 24px 20px;
  background: linear-gradient(90deg, #58cc02, #41a001);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 14px 0;
  font-size: 1rem;
  font-weight: 900;
  font-family: 'Nunito', sans-serif;
  letter-spacing: .04em;
  cursor: pointer;
  box-shadow: 0 4px 0 #2d7000;
  transition: transform .1s, box-shadow .1s;
}
.chap-cover-btn:hover { filter: brightness(1.07); }
.chap-cover-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 #2d7000; }

/* Conversation cover extras */
.conv-cover .chap-cover-emoji { font-size: 3rem; }
.chap-conv-speakers {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  margin: 8px 0;
}
.chap-conv-speaker {
  display: inline-block;
  font-size: .8rem;
  font-weight: 900;
  font-family: 'Nunito', sans-serif;
  padding: 3px 12px;
  border-radius: 20px;
  border: 2px solid currentColor;
  background: rgba(255,255,255,.06);
}

/* Cover exit animation */
@keyframes chap-cover-out {
  from { opacity:1; transform: scale(1); }
  to   { opacity:0; transform: scale(.96); max-height:0; margin:0; padding:0; }
}

/* Hidden segments (revealed after cover click) */
.chap-seg-hidden {
  display: none !important;
}

/* ── Rich text content inside segments ─────────────────── */
.rich-text {
  line-height: 1.8;
  font-size: .97rem;
  color: var(--txt);
}
.rich-text b, .rich-text strong { color: var(--acc); font-weight: 800; }
.rich-text i, .rich-text em { color: var(--txt2); font-style: italic; }
.rich-text mark { background: #fff7c2; color: #333; padding: 1px 3px; border-radius: 3px; }
.rich-text ul, .rich-text ol { padding-left: 1.4em; margin: 6px 0; }
.rich-text li { margin-bottom: 4px; }
.rich-text p { margin: 6px 0; }
.rich-text h1,.rich-text h2,.rich-text h3 {
  font-family: 'Lora', serif; font-weight: 700;
  color: var(--txt); margin: 10px 0 6px; line-height: 1.3;
}
.rich-text h1 { font-size: 1.25rem; }
.rich-text h2 { font-size: 1.1rem; }
.rich-text h3 { font-size: .97rem; }
.rich-text blockquote {
  border-left: 3px solid var(--acc);
  margin: 8px 0;
  padding: 4px 12px;
  color: var(--txt2);
  background: var(--s2);
  border-radius: 0 6px 6px 0;
}
.rich-text s { text-decoration: line-through; color: var(--txt2); }
.rich-text sub { font-size: .75em; }
.rich-text sup { font-size: .75em; }

/* ═══════════════════════════════════════════════════════
   v35.1 — CHAPTER CARDS ON LEARNING PATH
   ═══════════════════════════════════════════════════════ */

/* Override zigzag row for cards — stack centered */
.dl-card-row {
  justify-content: center !important;
  padding: 0 16px !important;
  margin: 0 0 4px !important;
}
.dl-card-row.r-left  { padding-left: 16px !important; }
.dl-card-row.r-right { padding-right: 16px !important; }

.dl-node-wrap { width: 100%; max-width: 420px; }

/* ── The chapter card itself ──────────────────────────── */
.dl-card {
  --card-color: #58cc02;
  --card-dk:    #46a302;
  position: relative;
  background: #fff;
  border: 2px solid var(--border);
  border-bottom: 4px solid var(--border2);
  border-radius: 16px;
  padding: 0;
  overflow: hidden;
  cursor: pointer;
  transition: transform .18s, box-shadow .18s;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
  width: 100%;
  text-align: left;
  font-family: 'Nunito', sans-serif;
  display: flex;
  flex-direction: column;
}
.dl-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.13);
}
.dl-card:hover .dl-card-preview { max-height: 130px; opacity: 1; }
.dl-card.active {
  border-color: var(--card-color);
  border-bottom-color: var(--card-dk);
  box-shadow: 0 4px 20px rgba(88,204,2,.2);
  animation: cardPulse 2.5s infinite;
}
.dl-card.done {
  background: linear-gradient(135deg,#f6fff0,#edfde0);
  border-color: #b8e9a0;
  border-bottom-color: #8cc870;
}
.dl-card.locked {
  background: #f5f5f5;
  border-color: #e0e0e0;
  border-bottom-color: #c8c8c8;
  cursor: not-allowed;
  opacity: .75;
  pointer-events: none;
}
.dl-card.locked:hover { transform: none; box-shadow: 0 2px 10px rgba(0,0,0,.07); }
.dl-card.no-story { opacity: .6; }

@keyframes cardPulse {
  0%,100% { box-shadow: 0 4px 20px rgba(88,204,2,.2), 0 0 0 0 rgba(88,204,2,.3); }
  50%      { box-shadow: 0 4px 20px rgba(88,204,2,.2), 0 0 0 8px rgba(88,204,2,0); }
}

/* Badge strip at top */
.dl-card-badge {
  background: var(--card-color, #58cc02);
  color: #fff;
  font-size: .65rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 12px;
  display: block;
}
.dl-card.done   .dl-card-badge { background: #8cc870; }
.dl-card.locked .dl-card-badge { background: #bbb; }

/* Status icon (done ✅ / locked 🔒) top-right */
.dl-card-status {
  position: absolute;
  top: 24px;
  right: 10px;
  font-size: 1.1rem;
  line-height: 1;
}

/* Image zone */
.dl-card-img {
  width: 100%;
  height: 110px;
  background-size: cover;
  background-position: center;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

/* Emoji fallback */
.dl-card-emoji {
  text-align: center;
  font-size: 2.4rem;
  padding: 14px 0 6px;
  line-height: 1;
}

/* Title */
.dl-card-title {
  font-size: 1.02rem;
  font-weight: 900;
  color: var(--txt);
  padding: 8px 14px 2px;
  letter-spacing: -.01em;
}
.dl-card-title-en {
  font-size: .76rem;
  color: var(--txt2);
  font-weight: 700;
  padding: 0 14px 8px;
}

/* Hover-reveal content preview */
.dl-card-preview {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .3s ease, opacity .25s ease;
  border-top: 1px solid var(--border);
  padding: 0 14px;
  background: var(--s2);
}
.dl-card-preview-line {
  font-size: .75rem;
  color: var(--txt2);
  line-height: 1.55;
  padding: 3px 0;
  border-bottom: 1px dotted var(--border);
}
.dl-card-preview-line:last-child { border-bottom: none; padding-bottom: 8px; }
.dl-card-preview-line:first-child { padding-top: 8px; }

/* Connector between cards */
.dl-connector {
  width: 4px;
  height: 20px;
  background: var(--border2);
  border-radius: 2px;
  margin: 0 auto;
}
.dl-connector.done { background: var(--acc); }

/* Mobile adjustments */
@media(max-width:480px){
  .dl-card-img  { height: 80px; }
  .dl-card-title { font-size: .9rem; }
  .dl-card-emoji { font-size: 2rem; padding: 10px 0 4px; }
}

/* ═══════════════════════════════════════════════════════
   v35.2 — CONV PORTRAIT, WEITER ALWAYS-ON, RICH DESC
   ═══════════════════════════════════════════════════════ */

/* Conversation speaker portrait (per dialogue line) */
.conv-speaker-portrait {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 4px;
  background: var(--s2);
  border-radius: 10px 10px 0 0;
  margin-bottom: -4px;
}
.conv-portrait-img {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--border);
  flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,.12);
}
.conv-portrait-name {
  font-size: .78rem;
  font-weight: 900;
  font-family: 'Nunito', sans-serif;
  padding: 2px 10px;
  border-radius: 20px;
  border: 2px solid currentColor;
  background: rgba(255,255,255,.6);
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* Weiter button — always visible from segment start */
.story-weiter-btn {
  display: inline-block;
  background: var(--acc);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 10px 28px;
  font-size: .95rem;
  font-weight: 900;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
  box-shadow: 0 3px 0 var(--acc-dk);
  transition: opacity .15s, transform .1s;
  letter-spacing: .03em;
}
.story-weiter-btn:hover { opacity: .9; transform: translateY(-1px); }
.story-weiter-btn:active { transform: translateY(1px); box-shadow: 0 1px 0 var(--acc-dk); }

/* Rich text in hub unit description */
#hub-desc { line-height: 1.7; }
#hub-desc b, #hub-desc strong { font-weight: 800; color: var(--txt); }
#hub-desc i, #hub-desc em { color: var(--txt2); }
#hub-desc ul, #hub-desc ol { padding-left: 1.4em; margin: 6px 0; }
#hub-desc li { margin-bottom: 3px; }
#hub-desc p { margin: 4px 0; }
#hub-desc blockquote {
  border-left: 3px solid var(--acc);
  padding: 3px 10px;
  margin: 6px 0;
  color: var(--txt2);
  background: var(--s2);
  border-radius: 0 6px 6px 0;
}
#hub-desc h1,#hub-desc h2,#hub-desc h3 {
  font-family:'Lora',serif;font-weight:700;
  color:var(--txt);margin:8px 0 4px;
}

/* ─── hub-desc rich text refinements ─── */
.hub-desc-rich p { margin: 2px 0 6px; }
.hub-desc-rich p:first-child { margin-top: 0; }
.hub-desc-rich p:last-child  { margin-bottom: 0; }
.hub-desc-rich ul, .hub-desc-rich ol { padding-left: 1.3em; margin: 4px 0; }
.hub-desc-rich li { margin-bottom: 2px; font-size: .88rem; }
.hub-desc-rich strong, .hub-desc-rich b { font-weight: 800; color: var(--txt); }
.hub-desc-rich em, .hub-desc-rich i { color: var(--txt2); }
.hub-desc-rich blockquote {
  border-left: 3px solid var(--acc); padding: 3px 10px;
  margin: 5px 0; color: var(--txt2); background: rgba(88,204,2,.06); border-radius: 0 6px 6px 0;
}

/* ══════════════════════════════════════════════════════
   LGG – LEARN WITH PICTURES  (Picture-Label Tab)
   ══════════════════════════════════════════════════════ */

/* ── Picture-label tab screen ── */
#pictures {
  padding: 0 0 120px;
}

/* ── Exercise list grid ── */
.pl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  max-width: 860px;
  margin: 24px auto 0;
  padding: 0 18px;
}

.pl-card {
  background: #fff;
  border: 2px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.pl-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}

.pl-card-img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  display: block;
  background: var(--s2);
}

.pl-card-body {
  padding: 10px 14px 13px;
}

.pl-card-title {
  font-family: 'Nunito', sans-serif;
  font-weight: 800;
  font-size: .95rem;
  color: var(--txt);
  margin-bottom: 4px;
}

.pl-card-meta {
  font-size: .78rem;
  color: var(--txt2);
  font-weight: 600;
}

.pl-card-badge {
  display: inline-block;
  background: var(--acc);
  color: #fff;
  border-radius: 20px;
  padding: 1px 9px;
  font-size: .72rem;
  font-weight: 800;
  margin-right: 5px;
}

/* ── Empty state ── */
.pl-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--txt2);
  font-size: 1rem;
}
.pl-empty .pl-empty-icon { font-size: 3.5rem; margin-bottom: 12px; }

/* ── Heading strip ── */
.pl-header {
  max-width: 860px;
  margin: 0 auto;
  padding: 24px 18px 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.pl-header h2 {
  font-family: 'Lora', serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--txt);
  margin: 0;
}

/* ══ EXERCISE SCREEN ══ */
#pl-exercise-screen {
  padding: 0 0 120px;
  /* display is controlled by .scr / .scr.on — do NOT set display:none here */
}
/* Support both .on (used by showScreen) and .active class names */
#pl-exercise-screen.on,
#pl-exercise-screen.active { display: block !important; }

.pl-ex-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 16px 18px 40px;
}

.pl-ex-title {
  font-family: 'Lora', serif;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--txt);
  margin: 12px 0 18px;
}

/* ── Image canvas (student) ── */
.pl-img-canvas {
  position: relative;
  display:  inline-block;
  width:    100%;
  max-width: 860px;
  user-select: none;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}

.pl-img-canvas img {
  display:   block;
  width:     100%;
  height:    auto;
}

/* Drop zones on image */
.pl-drop-zone {
  position:  absolute;
  background: rgba(255,255,255,0.82);
  border:    2.5px dashed #aaa;
  border-radius: 6px;
  display:   flex;
  align-items: center;
  justify-content: center;
  font-size: .82rem;
  font-weight: 800;
  font-family: 'Nunito', sans-serif;
  color:     #888;
  cursor:    pointer;
  transition: background .15s, border-color .15s;
  box-sizing: border-box;
  padding:   2px 4px;
  text-align: center;
  min-height: 28px;
  overflow:  hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.pl-drop-zone.drag-over {
  background: rgba(88,204,2,.18);
  border-color: var(--acc);
  border-style: solid;
}

.pl-drop-zone.filled {
  background: rgba(255,255,255,.92);
  border-style: solid;
  border-color: #94a3b8;
  color: var(--txt);
}

.pl-drop-zone.correct {
  background: rgba(34,197,94,.18);
  border-color: #16a34a;
  border-style: solid;
  color: #15803d;
}

.pl-drop-zone.wrong {
  background: rgba(239,68,68,.15);
  border-color: #dc2626;
  border-style: solid;
  color: #dc2626;
  animation: pl-shake .3s;
}

.pl-drop-zone.correct::after {
  content: ' ✓';
  color:   #16a34a;
  font-size: 1.1em;
}

.pl-drop-zone.wrong::after {
  content: ' ✗';
  color:   #dc2626;
  font-size: 1.1em;
}

@keyframes pl-shake {
  0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)}
}

/* ── Word bank ── */
.pl-word-bank {
  margin-top: 22px;
  display:    flex;
  flex-wrap:  wrap;
  gap:        10px;
  align-items: flex-start;
}

.pl-word-bank-label {
  width:     100%;
  font-size: .8rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  color:     var(--txt2);
  margin-bottom: 4px;
}

.pl-word-chip {
  background: var(--s2);
  border:    2px solid var(--border);
  border-radius: 8px;
  padding:   7px 16px;
  font-size: .88rem;
  font-weight: 800;
  font-family: 'Nunito', sans-serif;
  color:     var(--txt);
  cursor:    grab;
  transition: opacity .15s, transform .12s, box-shadow .12s;
  user-select: none;
  white-space: nowrap;
}

.pl-word-chip:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  border-color: var(--acc);
}

.pl-word-chip.dragging {
  opacity: .4;
  cursor: grabbing;
}

.pl-word-chip.used {
  opacity: .35;
  pointer-events: none;
}

/* ── Action buttons ── */
.pl-actions {
  margin-top: 24px;
  display:    flex;
  gap:        12px;
  flex-wrap:  wrap;
}

.pl-btn {
  padding:    10px 26px;
  border-radius: 10px;
  border:    none;
  font-size: .95rem;
  font-weight: 900;
  font-family: 'Nunito', sans-serif;
  cursor:    pointer;
  transition: opacity .15s, transform .1s;
}
.pl-btn:hover   { opacity:.9; transform:translateY(-1px); }
.pl-btn:active  { transform:translateY(1px); }

.pl-btn-submit {
  background: var(--acc);
  color:     #fff;
  box-shadow: 0 3px 0 var(--acc-dk);
}
.pl-btn-reset {
  background: var(--s2);
  color:     var(--txt);
  border:    2px solid var(--border);
}
.pl-btn-back {
  background: transparent;
  color:     var(--txt2);
  border:    2px solid var(--border);
}

/* ── Result banner ── */
.pl-result-banner {
  display:    none;
  margin-top: 20px;
  padding:    20px 24px;
  border-radius: 14px;
  text-align: center;
  font-family: 'Lora', serif;
}
.pl-result-banner.show { display: block; }
.pl-result-banner.all-correct {
  background: linear-gradient(135deg,#dcfce7,#bbf7d0);
  border:    2px solid #16a34a;
  color:     #15803d;
}
.pl-result-banner.has-wrong {
  background: linear-gradient(135deg,#fef2f2,#fecaca);
  border:    2px solid #dc2626;
  color:     #dc2626;
}
.pl-result-banner .pl-res-icon  { font-size:2.5rem; margin-bottom:8px; }
.pl-result-banner .pl-res-title { font-size:1.5rem; font-weight:700; margin-bottom:6px; }
.pl-result-banner .pl-res-score { font-size:1rem; font-family:'Nunito',sans-serif; }

/* ══════════════════════════════════════════════
   NEON DOT DROP ZONES  (picture-label exercise)
   ══════════════════════════════════════════════ */

/* Base dot */
.pl-dot-zone {
  position:   absolute;
  width:      28px;
  height:     28px;
  border-radius: 50%;
  transform:  translate(-50%, -50%);
  cursor:     pointer;
  display:    flex;
  align-items: center;
  justify-content: center;
  z-index:    10;
  transition: box-shadow .2s, transform .15s;
  user-select: none;
}
.pl-dot-zone:hover { transform: translate(-50%,-50%) scale(1.25); }

.pl-dot-zone-num {
  color:       #fff;
  font-size:   11px;
  font-weight: 900;
  font-family: 'Nunito',sans-serif;
  pointer-events: none;
  line-height: 1;
}

/* Floating word label that appears when filled */
.pl-dot-float-label {
  display:     none;
  position:    absolute;
  bottom:      calc(100% + 6px);
  left:        50%;
  transform:   translateX(-50%);
  background:  rgba(255,255,255,.96);
  color:       #1a1a2e;
  font-size:   11px;
  font-weight: 800;
  font-family: 'Nunito',sans-serif;
  padding:     3px 8px;
  border-radius: 6px;
  white-space: nowrap;
  box-shadow:  0 2px 8px rgba(0,0,0,.18);
  pointer-events: none;
  z-index:     20;
}
.pl-dot-float-label::after {
  content:   '';
  position:  absolute;
  top:       100%;
  left:      50%;
  transform: translateX(-50%);
  border:    5px solid transparent;
  border-top-color: rgba(255,255,255,.96);
}

/* States */
.pl-dot-zone.drag-over {
  transform: translate(-50%,-50%) scale(1.4);
  box-shadow: 0 0 0 4px rgba(255,255,255,.95), 0 0 20px 8px currentColor !important;
}
.pl-dot-zone.filled .pl-dot-float-label { display: block; }
.pl-dot-zone.filled .pl-dot-zone-num    { display: none; }
.pl-dot-zone.filled { cursor: pointer; }
.pl-dot-zone.filled:hover .pl-dot-float-label::after { content: ' ×'; color: #dc2626; font-weight: 900; }

.pl-dot-zone.correct {
  box-shadow: 0 0 0 3px rgba(255,255,255,.9), 0 0 14px 6px #16a34a, 0 0 28px 10px #16a34a88 !important;
  background: #16a34a !important;
}
.pl-dot-zone.correct .pl-dot-float-label { border: 2px solid #16a34a; color: #15803d; }
.pl-dot-zone.correct .pl-dot-float-label::before { content: '✓ '; color: #16a34a; }

.pl-dot-zone.wrong {
  box-shadow: 0 0 0 3px rgba(255,255,255,.9), 0 0 14px 6px #dc2626, 0 0 28px 10px #dc262688 !important;
  background: #dc2626 !important;
  animation: dot-shake .35s;
}
@keyframes dot-shake {
  0%,100%{ transform:translate(-50%,-50%) }
  25%{transform:translate(calc(-50% - 5px),-50%)}
  75%{transform:translate(calc(-50% + 5px),-50%)}
}
.pl-dot-zone.wrong .pl-dot-float-label { border: 2px solid #dc2626; color: #dc2626; }

/* ══════════════════════════════════════════════════════
   LERNEN / ÜBEN — lggclass.com style cards
   ══════════════════════════════════════════════════════ */

.learn-card {
  background:    #fff;
  border:        2px solid var(--border);
  border-radius: 18px;
  padding:       24px 20px 20px;
  text-align:    center;
  box-shadow:    0 4px 20px rgba(0,0,0,.07);
  margin-bottom: 16px;
  cursor:        default;
  transition:    box-shadow .15s;
}
.learn-card:hover { box-shadow: 0 6px 28px rgba(0,0,0,.11); }

/* English label (top, small caps) */
.learn-card-en {
  font-family:   'Nunito', sans-serif;
  font-size:     .78rem;
  font-weight:   900;
  letter-spacing:.1em;
  color:         var(--txt2);
  margin-bottom: 8px;
  text-transform: uppercase;
}

/* German word row */
.learn-card-de {
  display:       flex;
  align-items:   center;
  justify-content: center;
  gap:           10px;
  margin:        10px 0 6px;
  flex-wrap:     wrap;
}

/* Article badge (der/die/das) */
.learn-art-badge {
  display:       inline-flex;
  align-items:   center;
  justify-content: center;
  min-width:     44px;
  padding:       4px 10px;
  border-radius: 8px;
  color:         #fff;
  font-family:   'Nunito', sans-serif;
  font-weight:   900;
  font-size:     1rem;
}

/* Word */
.learn-word {
  font-family:   'Lora', serif;
  font-size:     1.8rem;
  font-weight:   700;
  color:         var(--txt);
  line-height:   1.2;
}

/* Audio button */
.learn-audio-btn {
  background:    none;
  border:        none;
  font-size:     1.3rem;
  cursor:        pointer;
  opacity:       .6;
  transition:    opacity .15s, transform .1s;
  padding:       4px;
  border-radius: 50%;
}
.learn-audio-btn:hover { opacity: 1; transform: scale(1.15); background: var(--s2); }

/* Hint text */
.learn-hint {
  font-size:     .8rem;
  color:         var(--txt2);
  margin-top:    12px;
  font-style:    italic;
}

/* "Got it — Weiter" button */
.learn-continue-btn {
  display:       block;
  width:         100%;
  padding:       14px;
  background:    var(--acc);
  color:         #fff;
  border:        none;
  border-radius: 12px;
  font-family:   'Nunito', sans-serif;
  font-size:     1rem;
  font-weight:   900;
  cursor:        pointer;
  box-shadow:    0 4px 0 var(--acc-dk);
  transition:    opacity .15s, transform .1s;
  letter-spacing:.02em;
}
.learn-continue-btn:hover  { opacity: .92; transform: translateY(-1px); }
.learn-continue-btn:active { transform: translateY(2px); box-shadow: 0 2px 0 var(--acc-dk); }

/* Practice card — dimmed until tapped */
.practice-card { cursor: pointer !important; }

/* ════════════════════════════════════════════════════
   DRAG WORDS TO FILL BLANK  (.dw-*)
════════════════════════════════════════════════════ */
.dw-sentence {
  font-size: 1.1rem;
  line-height: 2.2;
  margin: 14px 0 10px;
  color: var(--txt);
  font-weight: 600;
}
.dw-zone {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 80px;
  min-height: 36px;
  border: 2px dashed #a78bfa;
  border-radius: 8px;
  background: #f5f3ff;
  margin: 0 4px;
  cursor: pointer;
  vertical-align: middle;
  transition: background .15s, border-color .15s;
  padding: 2px 8px;
}
.dw-zone.dw-dragover { background: #ede9fe; border-color: #7c3aed; }
.dw-zone.dw-filled   { background: #ede9fe; border-style: solid; border-color: #7c3aed; }
.dw-zone.dw-correct  { background: #d1fae5; border-color: #16a34a; }
.dw-zone.dw-wrong    { background: #fee2e2; border-color: #ef4444; }
.dw-zone-placeholder { color: #a78bfa; font-size: .9em; font-weight: 600; letter-spacing: .1em; }
.dw-zone-word        { color: #5b21b6; font-weight: 700; font-size: 1em; }

.dw-bank {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 10px;
  padding: 12px;
  background: #f9f7ff;
  border: 1px solid #e0d7ff;
  border-radius: 12px;
  min-height: 54px;
}
.dw-tile {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  background: #fff;
  border: 2px solid #a78bfa;
  border-radius: 20px;
  font-size: .95rem;
  font-weight: 700;
  color: #5b21b6;
  cursor: grab;
  user-select: none;
  transition: opacity .15s, transform .1s, background .15s;
  box-shadow: 0 2px 6px rgba(124,58,237,.12);
}
.dw-tile:hover   { background: #ede9fe; transform: translateY(-2px); }
.dw-tile.dw-used { opacity: .3; cursor: default; pointer-events: none; }
.dw-tile.dw-dragging { opacity: .5; transform: scale(1.05); }

/* ════════════════════════════════════════════════════
   SENTENCE ORDER  (.so-*)
════════════════════════════════════════════════════ */
.so-slots-wrap {
  margin: 14px 0 8px;
  padding: 12px;
  background: #f0fdfe;
  border: 1px solid #a5f3fc;
  border-radius: 12px;
  min-height: 56px;
}
.so-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.so-slot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  min-height: 38px;
  padding: 4px 10px;
  border: 2px dashed #22d3ee;
  border-radius: 8px;
  background: #ecfeff;
  color: #0e7490;
  font-weight: 700;
  font-size: .95rem;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.so-slot.so-dragover { background: #cffafe; border-color: #06b6d4; }
.so-slot.so-filled   { background: #cffafe; border-style: solid; border-color: #0891b2; color: #0e7490; }
.so-slot.so-correct  { background: #d1fae5; border-color: #16a34a; color: #15803d; }
.so-slot.so-wrong    { background: #fee2e2; border-color: #ef4444; color: #dc2626; }

.so-bank {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
  padding: 12px;
  background: #f0fdfe;
  border: 1px solid #a5f3fc;
  border-radius: 12px;
  min-height: 54px;
}
.so-tile {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  background: #fff;
  border: 2px solid #22d3ee;
  border-radius: 20px;
  font-size: .95rem;
  font-weight: 700;
  color: #0e7490;
  cursor: grab;
  user-select: none;
  transition: opacity .15s, transform .1s, background .15s;
  box-shadow: 0 2px 6px rgba(6,182,212,.12);
}
.so-tile:hover    { background: #cffafe; transform: translateY(-2px); }
.so-tile.so-used  { opacity: .3; cursor: default; pointer-events: none; }
.so-tile.so-dragging { opacity: .5; transform: scale(1.05); }

/* ════════════════════════════════════════════════════
   MILESTONE SCREEN
════════════════════════════════════════════════════ */
#milestone-screen {
  background: linear-gradient(160deg, #fff8e1 0%, #fce4ec 50%, #e8f5e9 100%);
  min-height: 100vh;
}

/* ── Milestone complete popup overlay ── */
.ms-popup-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.55);
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.ms-popup-overlay.show {
  display: flex !important;
}

/* ── Streak / Trophy popup ── */
#streak-popup {
  display: none;
  position: fixed;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 8000;
  pointer-events: none;
}
#streak-popup.show {
  display: block !important;
  animation: streakPop .5s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes streakPop {
  from { transform: translateX(-50%) scale(.3) translateY(30px); opacity: 0; }
  to   { transform: translateX(-50%) scale(1) translateY(0);     opacity: 1; }
}

/* ── Confetti canvas ── */
#ms-confetti-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

/* ── Milestone card in popup ── */
#ms-complete-card {
  background: #fff;
  border-radius: 24px;
  padding: 40px 36px;
  text-align: center;
  max-width: 380px;
  width: 90%;
  position: relative;
  z-index: 1;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
  animation: msPopIn .5s cubic-bezier(.175,.885,.32,1.275);
}
@keyframes msPopIn {
  from { transform: scale(.4) rotate(-8deg); opacity: 0; }
  to   { transform: scale(1)  rotate(0deg);  opacity: 1; }
}

/* ── Floating star decorations ── */
.ms-star {
  position: absolute;
  font-size: 1.5rem;
  animation: msSpin 6s linear infinite;
  opacity: .5;
  pointer-events: none;
}
.ms-star1 { top: 10%; left: 8%;   animation-duration: 7s; }
.ms-star2 { top: 15%; right: 10%; animation-duration: 5s; animation-direction: reverse; }
.ms-star3 { bottom: 12%; left: 15%;  animation-duration: 8s; }
.ms-star4 { bottom: 8%;  right: 8%;  animation-duration: 6s; animation-direction: reverse; }
@keyframes msSpin {
  0%   { transform: rotate(0deg)   scale(1);   }
  50%  { transform: rotate(180deg) scale(1.3); }
  100% { transform: rotate(360deg) scale(1);   }
}

/* ── Milestone progress bar ── */
#ms-prog {
  height: 100%;
  background: linear-gradient(90deg, #ff9800, #e65100);
  border-radius: 3px;
  transition: width .4s ease;
  width: 0%;
}

/* ── Milestone question area reuses aufg-card styles ── */
#ms-area .aufg-card {
  background: #fff;
  border-radius: 18px;
  padding: 24px 20px;
  margin-bottom: 20px;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  border: 2px solid #ffe082;
}
#ms-area .aufg-card-num {
  font-size: .78rem;
  font-weight: 800;
  color: #e65100;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 6px;
}
#ms-area .aufg-card-badge {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: .8rem;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, #ff9800, #e65100);
  margin-bottom: 14px;
}

/* ── Permission-locked section (teacher-controlled) ── */
.dl-section-hdr.lgc-perm-locked {
  background: #f3f4f6;
  border-bottom: 3px solid #d1d5db;
  opacity: 0.85;
}
.lgc-perm-hint {
  font-size: .78rem;
  color: #6b7280;
  margin-top: 5px;
  font-weight: 600;
  letter-spacing: .01em;
}
.lgc-perm-hint a { color: #1cb0f6; }
