:root{
  --bg:#ffffff;
  --panel:#ffffff;
  --panel-2:#f4f6f9;
  --line:#e4e8ee;
  --text:#131a2e;
  --muted:#5b6676;
  --accent:#2da05b;
  --accent-2:#27904f;
  --danger:#e5484d;
  --radius:16px;
  --shadow:0 10px 30px rgba(19,26,46,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
#app{min-height:100%;display:flex;flex-direction:column}

/* Kopfzeile */
.topbar{
  display:flex;align-items:center;gap:12px;
  padding:14px 24px;background:#fff;border-bottom:1px solid var(--line);
}
.brand-lock{display:flex;align-items:center;gap:10px}
.brand-mark{height:30px;width:auto;display:block}
.brand{font-weight:800;font-size:19px;letter-spacing:.2px;color:var(--text)}
.brand-sub{color:var(--muted);font-size:14px}

/* Screens */
.screen{display:none;flex:1;padding:40px 20px;align-items:flex-start;justify-content:center}
.screen.active{display:flex}
.screen.fullbleed{padding:0;align-items:stretch}

.card{
  width:100%;max-width:720px;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:40px;margin-top:12px;
}
.card.center{text-align:center}

h1{font-size:34px;line-height:1.15;margin:0 0 14px;color:var(--text)}
h2{font-size:26px;margin:0 0 12px;color:var(--text)}
.lead{color:var(--muted);font-size:17px;line-height:1.55;margin:0 0 22px}
.hint{color:var(--muted);font-size:13px;margin-top:16px}

.checklist{list-style:none;padding:0;margin:0 0 26px;text-align:left;max-width:460px;margin-inline:auto}
.checklist li{position:relative;padding:10px 0 10px 30px;border-bottom:1px solid var(--line);color:var(--text)}
.checklist li:before{content:"\2713";position:absolute;left:4px;color:var(--accent);font-weight:800}

/* Buttons */
.btn{
  appearance:none;border:0;cursor:pointer;font-weight:700;
  border-radius:12px;padding:14px 22px;font-size:16px;
  transition:transform .05s ease,background .15s ease,opacity .15s ease,border-color .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-lg{padding:16px 30px;font-size:18px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2)}
.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--line)}
.btn-secondary:hover{border-color:var(--accent)}
.btn-ghost{background:transparent;color:var(--muted);margin-top:16px}
.btn-ghost:hover{color:var(--text)}
.btn[disabled]{opacity:.5;cursor:default}

.field{display:flex;flex-direction:column;gap:6px;flex:1;text-align:left}
.field span{font-size:13px;color:var(--muted)}
select{
  background:#fff;color:var(--text);border:1px solid var(--line);
  border-radius:10px;padding:12px;font-size:15px;
}
.controls-row{display:flex;gap:14px;margin:18px 0}

/* Vorschau */
.preview-wrap{
  position:relative;background:#0b0f1a;border-radius:14px;overflow:hidden;
  aspect-ratio:16/9;border:1px solid var(--line);
}
#preview,#playback{width:100%;height:100%;object-fit:cover;display:block;background:#0b0f1a}
#preview{transform:scaleX(-1)} /* Spiegel nur in der Vorschau, natuerlicher */

.mic-meter{height:8px;background:var(--panel-2);border-radius:6px;overflow:hidden;margin:14px 0 22px;border:1px solid var(--line)}
.mic-meter span{display:block;height:100%;width:0;background:var(--accent);transition:width .08s linear}

.error{color:var(--danger);font-size:14px;margin-top:14px}
.hidden{display:none !important}

/* Aufnahme-Screen */
#screen-record{position:relative;background:#0b0f1a;overflow:hidden}
#stage{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}

.teleprompter{
  position:absolute;left:50%;top:56px;transform:translateX(-50%);
  width:min(1040px,92vw);height:82vh;overflow:hidden;
  background:rgba(255,255,255,.9);border:1px solid rgba(19,26,46,.06);
  border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.25);
  -webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 90%,transparent);
          mask-image:linear-gradient(to bottom,#000 0%,#000 90%,transparent);
}
.tp-inner{
  padding:20px 44px 40px;
  font-size:20px;line-height:1.4;font-weight:400;
  color:var(--text);text-align:center;white-space:pre-wrap;
  will-change:transform;
}
.tp-readline{display:none}

.countdown{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:22vw;font-weight:800;color:#fff;background:rgba(11,15,26,.3);
  text-shadow:0 4px 30px rgba(0,0,0,.5);z-index:5;
}

.rec-hud{position:absolute;top:16px;left:0;right:0;display:flex;justify-content:center;z-index:4}
.rec-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(11,15,26,.72);color:#fff;
  padding:8px 14px;border-radius:999px;font-weight:700;font-size:14px;
}
.rec-badge .dot{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:pulse 1s infinite}
.rec-badge em{font-style:normal;color:#c7cede;font-variant-numeric:tabular-nums}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.rec-toolbar{
  position:absolute;left:0;right:0;bottom:0;z-index:4;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 20px;background:linear-gradient(to top,rgba(11,15,26,.55),transparent);
  flex-wrap:wrap;
}
.tp-controls{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  background:rgba(255,255,255,.95);color:var(--text);border:1px solid rgba(255,255,255,.6);
  border-radius:999px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.chip:hover{background:#fff}
.rec-buttons{display:flex;gap:10px;margin-left:auto}
.btn-record{background:var(--danger);color:#fff}
.btn-record:hover{background:#f05a5f}
.btn-stop{background:#fff;color:var(--text)}

/* Review */
.review-actions{display:flex;gap:14px;margin-top:20px}
.review-actions .btn{flex:1}

/* Upload */
.progress{height:12px;background:var(--panel-2);border-radius:8px;overflow:hidden;margin:22px 0;border:1px solid var(--line)}
.progress-bar{height:100%;width:0;background:var(--accent);transition:width .2s ease}

.checkmark{
  width:76px;height:76px;border-radius:50%;background:var(--accent);
  color:#fff;font-size:40px;display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
}

@media (max-width:560px){
  .controls-row,.review-actions{flex-direction:column}
  h1{font-size:28px}
  .tp-inner{font-size:16px}
}
