/* ─────────────────────────────────────────────────────────────
   Hollermeier Loom · Branding & UI
   Palette angelehnt an hollermeierdigital.com
   ───────────────────────────────────────────────────────────── */
:root{
  --cream:#F1F1E9;
  --cream-2:#E9E9DE;
  --forest:#16241A;
  --forest-2:#1E2E22;
  --forest-3:#27392B;
  --copper:#BE7B3C;
  --copper-dark:#A5672E;
  --copper-soft:#E7C9A4;
  --ink:#1C1C19;
  --muted:#6E6E64;
  --line:rgba(28,28,25,.10);
  --card:#FFFFFF;
  --good:#3E7D52;
  --danger:#B5462F;
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 10px 30px rgba(22,36,26,.10);
  --shadow-sm:0 4px 14px rgba(22,36,26,.08);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--copper-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
h1,h2,h3{line-height:1.15;letter-spacing:-.01em;font-weight:700;margin:0 0 .4em}
h1{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h2{font-size:clamp(1.3rem,2.4vw,1.9rem)}
.muted{color:var(--muted)}
.center{text-align:center}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
.narrow{max-width:560px;margin:0 auto;padding:0 22px}

/* ── Grid-Hintergrund wie auf der Website ── */
.gridbg{
  background-color:var(--cream);
  background-image:
    linear-gradient(rgba(28,28,25,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(28,28,25,.045) 1px,transparent 1px);
  background-size:64px 64px;
}

/* ── Topbar ── */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;max-width:1120px;margin:0 auto;
}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:1.15rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand svg{width:34px;height:34px}
.nav{display:flex;align-items:center;gap:22px}
.nav a{color:var(--ink);font-weight:500;font-size:.95rem}
.nav a.active{color:var(--copper-dark)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:.98rem;
  padding:13px 26px;border-radius:999px;transition:.15s;text-decoration:none;
  background:var(--copper);color:#fff;box-shadow:var(--shadow-sm);
}
.btn:hover{background:var(--copper-dark);text-decoration:none;transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn.dark{background:var(--forest)}
.btn.dark:hover{background:var(--forest-2)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:none;border:1.5px solid var(--line)}
.btn.ghost:hover{background:rgba(0,0,0,.04);color:var(--ink)}
.btn.danger{background:var(--danger)}
.btn.sm{padding:8px 16px;font-size:.9rem}
.btn.block{width:100%}
.btn svg{width:18px;height:18px}

/* ── Cards ── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}
.card.flat{box-shadow:var(--shadow-sm)}

/* ── Formulare ── */
label{display:block;font-weight:600;font-size:.9rem;margin:14px 0 6px}
input[type=text],input[type=email],input[type=password],input[type=url],textarea,select{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:1rem;background:#fff;color:var(--ink);
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--copper)}
textarea{min-height:96px;resize:vertical}
.hint{font-size:.82rem;color:var(--muted);margin-top:5px}
.field-row{display:flex;gap:16px;flex-wrap:wrap}
.field-row>*{flex:1;min-width:180px}

/* ── Meldungen ── */
.alert{padding:12px 16px;border-radius:12px;margin:14px 0;font-size:.92rem}
.alert.err{background:#fbe9e4;color:#8a2f1c;border:1px solid #f0c4b7}
.alert.ok{background:#e6f1e9;color:#245c39;border:1px solid #bcd9c6}

/* ── Auth-Screen ── */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:410px}
.auth-card .brand{justify-content:center;margin-bottom:6px}

/* ── Setup ── */
.steps{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.step{flex:1;min-width:120px;font-size:.82rem;color:var(--muted);padding:10px 12px;border-radius:12px;background:#fff;border:1.5px solid var(--line)}
.step.active{border-color:var(--copper);color:var(--ink)}
.step.done{border-color:var(--good);color:var(--good)}
.step b{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}

/* ── Dashboard ── */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:30px 0 20px}
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:26px}
.stat{background:var(--card);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm)}
.stat .n{font-size:1.7rem;font-weight:700;letter-spacing:-.02em}
.stat .l{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.vcard{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.15s}
.vcard:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.vthumb{position:relative;aspect-ratio:16/9;background:var(--forest);display:block;overflow:hidden}
.vthumb img{width:100%;height:100%;object-fit:cover}
.vthumb .dur{position:absolute;right:8px;bottom:8px;background:rgba(0,0,0,.72);color:#fff;font-size:.75rem;padding:2px 7px;border-radius:6px;font-variant-numeric:tabular-nums}
.vthumb .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;opacity:.9}
.vthumb .play svg{width:46px;height:46px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.vbody{padding:14px 16px}
.vbody .t{font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vbody .m{font-size:.82rem;color:var(--muted);display:flex;gap:12px}
.empty{text-align:center;padding:60px 20px;color:var(--muted)}

/* ── Record Studio ── */
.studio{display:grid;grid-template-columns:1fr 320px;gap:24px;margin-top:24px}
@media(max-width:860px){.studio{grid-template-columns:1fr}}
.stage{background:var(--forest);border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}
.stage canvas,.stage video{width:100%;height:100%;object-fit:contain;background:#000}
.stage .placeholder{color:#cfd8d1;text-align:center;padding:30px;position:absolute}
.rec-dot{position:absolute;top:14px;left:14px;display:none;align-items:center;gap:8px;background:rgba(0,0,0,.55);color:#fff;padding:6px 12px;border-radius:999px;font-size:.85rem;font-variant-numeric:tabular-nums}
.rec-dot.on{display:flex}
.rec-dot i{width:10px;height:10px;border-radius:50%;background:#ff4d4d;animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.controls{display:flex;flex-direction:column;gap:14px}
.toggle{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border:1.5px solid var(--line);border-radius:14px;background:#fff}
.toggle .lbl{font-weight:600;font-size:.92rem}
.toggle .lbl small{display:block;font-weight:400;color:var(--muted);font-size:.78rem}
.switch{position:relative;width:44px;height:26px;flex:0 0 44px}
.switch input{opacity:0;width:0;height:0}
.switch span{position:absolute;inset:0;background:#d7d7cd;border-radius:999px;transition:.15s;cursor:pointer}
.switch span:before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.15s}
.switch input:checked+span{background:var(--copper)}
.switch input:checked+span:before{transform:translateX(18px)}

/* ── Public Player ── */
.player-page{max-width:960px;margin:0 auto;padding:24px 22px 60px}
.player-shell{position:relative;background:#000;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.player-shell video{width:100%;display:block;background:#000;aspect-ratio:16/9;object-fit:contain}
.pbar{position:absolute;left:0;right:0;bottom:0;padding:10px 14px 12px;
  background:linear-gradient(transparent,rgba(0,0,0,.65));opacity:0;transition:.2s}
.player-shell:hover .pbar,.player-shell.paused .pbar{opacity:1}
.scrub{position:relative;height:6px;background:rgba(255,255,255,.25);border-radius:6px;cursor:pointer;margin-bottom:10px}
.scrub .buf{position:absolute;left:0;top:0;bottom:0;background:rgba(255,255,255,.3);border-radius:6px}
.scrub .played{position:absolute;left:0;top:0;bottom:0;background:var(--copper);border-radius:6px;width:0}
.scrub .knob{position:absolute;top:50%;width:14px;height:14px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);left:0}
.pctrls{display:flex;align-items:center;gap:14px;color:#fff}
.pctrls button{background:none;border:none;color:#fff;cursor:pointer;display:flex;padding:4px}
.pctrls svg{width:22px;height:22px}
.pctrls .time{font-size:.82rem;font-variant-numeric:tabular-nums}
.pctrls .spacer{flex:1}
.big-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.25);cursor:pointer}
.big-play svg{width:80px;height:80px;color:#fff;filter:drop-shadow(0 4px 14px rgba(0,0,0,.5))}

/* ── Über-mich-Box ── */
.about{display:flex;gap:18px;align-items:center;margin-top:26px;background:var(--forest);color:#eef2ee;border-radius:var(--radius-lg);padding:22px 24px}
.about img{width:76px;height:76px;border-radius:50%;object-fit:cover;flex:0 0 76px;border:2px solid var(--copper)}
.about .avatar-fallback{width:76px;height:76px;border-radius:50%;flex:0 0 76px;background:var(--copper);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.6rem}
.about h3{color:#fff;margin-bottom:3px}
.about p{margin:0;font-size:.92rem;color:#cfe0d3}

/* ── Stats-Detail ── */
.retention{background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);margin-top:20px}
.chart{width:100%;height:180px}
.legend{display:flex;gap:18px;font-size:.82rem;color:var(--muted);margin-top:10px}
.legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:6px;vertical-align:-1px}

table.data{width:100%;border-collapse:collapse;font-size:.9rem}
table.data th,table.data td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
table.data th{font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}

.share-box{display:flex;gap:8px;margin-top:8px}
.share-box input{background:var(--cream)}
.copytag{font-size:.8rem;color:var(--good);margin-left:8px;opacity:0;transition:.2s}
.copytag.show{opacity:1}

footer.foot{text-align:center;color:var(--muted);font-size:.82rem;padding:40px 20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;align-items:center}
footer.foot a{color:var(--muted);text-decoration:underline}
footer.foot a:hover{color:var(--ink)}
footer.foot .sep{opacity:.4}

/* ── Logo-Bild (statt Fuchs-SVG, wenn hochgeladen) ── */
.brand-logo{height:38px;width:auto;max-width:200px;object-fit:contain;display:block}
.brand.center-logo{justify-content:center}

/* ── Fix: Buttons in der Navigation behalten weißen Text ──
   (.nav a setzt sonst dunkle Textfarbe -> „schwarz auf schwarz“) ── */
.nav a.btn{color:#fff}
.nav a.btn:hover{color:#fff;text-decoration:none}
.nav a.btn.ghost{color:var(--ink)}

/* ── Kamera-Position im Studio ── */
.campos{border:1.5px solid var(--line);border-radius:14px;padding:12px 14px;background:#fff}
.campos .lbl{font-weight:600;font-size:.92rem;margin-bottom:8px}
.corner-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.corner-btns button{border:1.5px solid var(--line);background:var(--cream);border-radius:10px;padding:10px;cursor:pointer;font-size:1.1rem;line-height:1;transition:.12s}
.corner-btns button:hover{border-color:var(--copper)}
.corner-btns button.active{border-color:var(--copper);background:var(--copper-soft)}
.campos small{display:block;color:var(--muted);font-size:.78rem;margin-top:8px}
.stage canvas.draggable{cursor:grab}
.stage canvas.grabbing{cursor:grabbing}
