:root{
  --bg:#0b0c10; --card:#12141a; --text:#f2f3f5; --muted:#99a1b3; --brand:#1db954;
  --danger:#e11d48; --ok:#22c55e; --warn:#f59e0b; --radius:16px;
  --border:#20232b; --field:#0f1218; --btn:#171a21; --btn-border:#2a2f36;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}

/* Base */
*{
  box-sizing:border-box;
  -webkit-tap-highlight-color:transparent; /* iOS/Chrome Mobile: blauen Tap-Rahmen aus */
}
html,body{
  margin:0; height:100%; background:var(--bg); color:var(--text);
  font-family:system-ui, Segoe UI, Roboto, Arial, sans-serif;
  -webkit-text-size-adjust:100%;
}
:focus{ outline:none }
:focus-visible{
  box-shadow:0 0 0 3px color-mix(in oklab, var(--brand) 45%, transparent);
  border-radius:12px;
}
@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:10;
  padding:10px calc(16px + env(safe-area-inset-right)) 10px calc(16px + env(safe-area-inset-left));
  background:#0c0e14;
  box-shadow:0 2px 0 rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.topbar h1{
  margin:0;
  font-size:clamp(16px, 2.4vw, 20px);
  white-space:nowrap;
}
.muted{
  color:var(--muted);
  font-weight:500;
}

/* Actions rechts in der Topbar (QR öffnen + Logout) */
.topbar-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.topbar-actions .btn{
  /* typischerweise .btn.btn-xs */
  white-space:nowrap;
}

/* Spezielle Styles für QR- & Logout-Button in der Topbar */
#btnQrOpen{
  background:rgba(34,197,94,.15);
  border-color:rgba(34,197,94,.55);
  color:#bbf7d0;
  opacity:1;
}
#btnLogout{
  background:rgba(225,29,72,.2);
  border-color:rgba(225,29,72,.6);
  color:#fff;
  opacity:1;
}
@media (hover:hover){
  #btnQrOpen:hover{
    background:rgba(34,197,94,.22);
  }
  #btnLogout:hover{
    background:rgba(225,29,72,.3);
  }
}

@media (max-width:420px){
  .topbar{
    padding-inline:12px;
  }
}

/* Layout */
.container{
  padding:8px;
  display:grid;
  gap:8px;
  max-width:720px;
  margin:0 auto 0px;
}
.card{
  background:var(--card);
  border-radius:var(--radius);
  padding:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}
h2{
  margin:0 0 12px;
  font-size:clamp(18px, 2.5vw, 18px);
}

/* Now Playing */
.nowplaying{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:12px;
  align-items:center;
  background:#0f1218;
  border:1px solid #282f3a;
  border-radius:14px;
  padding:10px;
  margin-bottom:12px;
}
.np-cover{
  width:72px; height:72px;
  border-radius:10px;
  object-fit:cover;
  background:#0b0e14;
  border:1px solid #222834;
}
.np-text{ min-width:0 }
.np-title{
  font-weight:700;
  font-size:16px;
  line-height:1.25;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.np-artists{
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.np-progress{
  margin-top:8px;
  height:6px;
  background:#1a1e27;
  border-radius:999px;
  overflow:hidden;
}
.np-bar{
  height:100%;
  width:0%;
  background:var(--brand);
}
@media (min-width:560px){
  .np-cover{ width:84px; height:84px }
  .np-title{ font-size:18px }
}

/* Status Grid – nebeneinander */
.status-grid.two{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  align-items:end;
}
.status-grid .label{
  color:var(--muted);
  font-size:12px;
  margin-bottom:4px;
}

/* Form & Fields */
.field{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin:10px 0;
}
.field > span{
  color:var(--muted);
  font-size:13px;
  display:block;
}
input,select,textarea{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid #28303a;
  background:var(--field);
  color:var(--text);
  font-size:16px;
  transition:border-color .15s ease, box-shadow .15s ease;
}

/* Autofill-Hintergrund an unser Design anpassen */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0px 1000px var(--field) inset;
  -webkit-text-fill-color:var(--text);
  transition:background-color 9999s ease-out 0s;
}

textarea{
  min-height:96px;
  resize:vertical;
}
input::placeholder{
  color:color-mix(in oklab, var(--muted) 80%, transparent);
}
input:focus-visible,
select:focus-visible{
  border-color:color-mix(in oklab, var(--brand) 55%, #28303a);
}

/* Rows & Buttons */
.row{
  display:block;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.btn{
  appearance:none;
  border:1px solid var(--btn-border);
  background:var(--btn);
  color:var(--text);
  padding:12px 16px;
  border-radius:12px;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  text-align:center;
  transition:transform .06s ease, border-color .15s ease, background-color .15s ease;
}
.btn:active{ transform:translateY(1px) }
.btn.primary{
  background:var(--brand);
  border-color:var(--brand);
  color:#0b0c10;
  font-weight:600;
}
.btn.danger{
  background:var(--danger);
  border-color:var(--danger);
  color:#fff;
}
.btn.subtle{ opacity:.9 }
.btn.outline{ background:transparent }
.btn.block{ width:100% }
.btn-xs{
  padding:8px 10px;
  border-radius:10px;
  min-height:36px;
  font-size:13px;
}
.btn:disabled{
  opacity:.6;
  cursor:not-allowed;
}

/* Badges */
.badge{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--btn-border);
  background:var(--field);
  min-width:auto;
  text-align:center;
  white-space:nowrap;
  font-size:13px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.badge.ok{
  background:rgba(34,197,94,.15);
  border-color:rgba(34,197,94,.35);
}
.badge.warn{
  background:rgba(245,158,11,.15);
  border-color:rgba(245,158,11,.35);
}
.badge.err{
  background:rgba(225,29,72,.15);
  border-color:rgba(225,29,72,.35);
}

/* QR – wird im Popup & in Karten genutzt */
.qr-wrap{
  display:grid;
  place-items:center;
  gap:10px;
  margin-top:8px;
}
.qr-img{
  width:min(260px, 70vw);
  height:auto;
  border-radius:12px;
  background:transparent;
  border:none;
  padding:0;
}
.qr-link{
  margin:6px 0 2px;
  font-size:13px;
}
.qr-link a{
  color:var(--text);
  text-decoration:none;
  border-bottom:1px dotted #3a465c;
  overflow-wrap:anywhere;
  word-break:break-all;
}
.qr-link a:hover{
  text-decoration:underline;
}
.qr-actions{
  display:flex;
  gap:10px;
  flex-wrap:nowrap;
  width:100%;
}
.qr-actions .btn{
  flex:1 0 0;
}

/* Toast */
.toast{
  position:fixed;
  left:50%;
  bottom:calc(16px + env(safe-area-inset-bottom));
  transform:translateX(-50%);
  background:#171a21;
  border:1px solid var(--btn-border);
  color:var(--text);
  padding:10px 14px;
  border-radius:999px;
  box-shadow:var(--shadow);
  max-width:min(90vw, 520px);
  text-align:center;
}

/* ===== Modal (Inline Confirm & QR-Overlay) ===== */
body.modal-open{ overflow:hidden; }
.modal-overlay[hidden]{
  display:none !important;
  pointer-events:none;
  opacity:0;
}
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:grid;
  place-items:center;
  z-index:1000;
}
.modal-card{
  width:min(520px, calc(100vw - 32px));
  background:var(--card);
  border:1px solid #2a2f36;
  border-radius:var(--radius);
  box-shadow:0 10px 30px rgba(0,0,0,.5);
  padding:16px;
}
.modal-body{
  padding:6px 2px 12px;
}
.modal-text{
  font-size:15px;
  line-height:1.4;
}
.modal-actions{
  display:flex;
  gap:10px;
  flex-wrap:nowrap;
  align-items:stretch;
}
.modal-actions .btn{
  flex:1 1 0;
  width:auto;
}
.modal-actions .btn.danger{
  margin-top:0;
}
@media (min-width:560px){
  .modal-actions .btn{ min-width:140px }
}

/* Desktop Hover */
@media (hover:hover){
  .btn:hover{ border-color:#3a465c }
}

/* kleine Tuning-Breakpoints */
@media (max-width:380px){
  .np-cover{ width:64px; height:64px }
  .np-title{ font-size:15px }
}
@media (min-width:700px){
  .container{ gap:20px }
  .topbar h1{ font-size:20px }
}

/* kleine Hilfsklassen */
.hint{
  color:var(--muted);
  font-size:12px;
  text-align:center;
}
.hint a{
  color:var(--brand);
  text-decoration:none;
  font-weight:500;
}
.hint a:hover{
  text-decoration:underline;
}
.label{ color:var(--muted) }

/* =========================================================
   COLLAPSIBLE CARDS (Regeln / ggf. weitere)
   ========================================================= */

/* Header der klappbaren Karten: Titel links, Pfeil rechts */
.card-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
}
.card-header h2{
  margin:0;
}

/* leichter Abstand des Inhalts zur Überschrift */
.card-collapsible .card-body{
  margin-top:10px;
}

/* Pfeil-Button oben rechts – Brand-Grün, ohne Hintergrund */
.card-toggle,
[data-card-toggle]{
  margin-left:auto;
  padding:4px;
  background:transparent;
  border:none;
  color:var(--brand);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  min-height:auto;
  font-size:0; /* evtl. Text ausblenden, wir zeichnen den Pfeil selbst */
}

/* Falls noch .btn/.btn-xs auf dem Element hängen, diese neutralisieren */
.card-toggle.btn,
.card-toggle.btn-xs,
[data-card-toggle].btn,
[data-card-toggle].btn-xs{
  background:transparent;
  border:none;
  box-shadow:none;
}

/* Beim Klick (Maus/Touch) keine zusätzliche Fokus-Markierung anzeigen */
.card-toggle:focus,
[data-card-toggle]:focus{
  outline:none;
  box-shadow:none;
}

/* Visueller Fokus-Ring nur um den Pfeil (Tastatur-Navigation) */
.card-toggle:focus-visible,
[data-card-toggle]:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px color-mix(in oklab, var(--brand) 60%, transparent);
}

/* Basispfeil: „V“ (nach unten) – Standardzustand: Karte geschlossen */
.card-toggle::before,
[data-card-toggle]::before{
  content:"";
  display:block;
  width:11px;
  height:11px;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  transform-origin:center;
  transform:rotate(135deg);          /* nach unten zeigend */
  transition:transform .16s ease;
}

/* Karte offen → Pfeil nach oben drehen */
.card-collapsible[data-collapsed="false"] .card-toggle::before,
.card-collapsible[data-collapsed="false"] [data-card-toggle]::before{
  transform:rotate(-45deg);          /* nach oben zeigend */
}

/* Optionale Hover-Highlight nur für Devices mit Hover */
@media (hover:hover){
  .card-toggle:hover,
  [data-card-toggle]:hover{
    color:color-mix(in oklab, var(--brand) 80%, #ffffff 10%);
  }
}

/* =========================================================
   LOGIN LAYOUT (HQ-Login, Client-Login, Admin-Login)
   ========================================================= */
body.login-wrapper{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  background:var(--bg);
}

.login-main{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 10px 10px;
}
@media (min-width:600px){
  .login-main{ align-items:center }
}

body.login-wrapper.login-success .login-main{
  align-items:center;
}

/* Wrapper für Login + Meta-Infos */
.login-shell{
  width:min(520px, 100%);
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* Obere Info-Karten (Branding + Subdomain) */
.login-meta-grid{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.login-meta-card{
  padding:10px 0px;
}

.login-meta-label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.03em;
  color:var(--muted);
  margin-bottom:4px;
}

.login-meta-value{
  font-weight:600;
  font-size:15px;
  overflow-wrap:anywhere;
}

.login-card{
  width:100%;
  background:var(--card);
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  padding:12px 20px 6px;
}

.login-card h2{
  margin:0 0 6px;
  font-size:20px;
}
.login-sub{
  margin:0 0 16px;
  color:var(--muted);
  font-size:14px;
  line-height:1.45;
}
.login-note{
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
  text-align:center;
}

/* Meldungen im Login */
.login-alert{
  margin-bottom:0px;
  padding:9px 11px;
  border-radius:12px;
  font-size:14px;
  border:1px solid transparent;
  text-align:center;
}
.login-alert.error{
  background:rgba(225,29,72,.12);
  border-color:rgba(225,29,72,.35);
}
.login-alert.ok{
  background:rgba(34,197,94,.12);
  border-color:rgba(34,197,94,.35);
}

/* =========================================================
   Passwort-Feld mit Toggle
   ========================================================= */
.pw-field .pw-wrap{
  position:relative;
  display:flex;
  align-items:center;
}
.pw-field .pw-wrap input{
  padding-right:44px; /* Platz für das Icon */
}

.pw-toggle{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:transparent;
  padding:4px;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.pw-toggle:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px color-mix(in oklab, var(--brand) 60%, transparent);
}

/* SVG-Icons */
.pw-icon{
  width:20px;
  height:20px;
  stroke:var(--muted);
  fill:none;
  stroke-width:1.7;
}

.pw-icon-hide{ display:none; }

/* Wenn sichtbar: grün & Icon wechseln */
.pw-toggle.pw-visible .pw-icon{
  stroke:var(--brand);
}
.pw-toggle.pw-visible .pw-icon-show{ display:none; }
.pw-toggle.pw-visible .pw-icon-hide{ display:block; }

/* =========================================================
   HQ – Signup Requests (requests.php)
   ========================================================= */

.hq-requests{
  max-width:1200px;
}

.req-wrap{
  display:grid;
  gap:16px;
}
.req-wrap.has-split{
  grid-template-columns:minmax(0, 1.1fr) minmax(0, 1.2fr);
  align-items:flex-start;
}
@media (max-width:960px){
  .req-wrap.has-split{
    grid-template-columns:1fr;
  }
}

.req-toolbar{
  margin-bottom:4px;
}

/* 4er-Grid für Status, Suche, Filtern, "Alle schließen" */
.req-filter-grid{
  display:grid;
  gap:8px;
  grid-template-columns:repeat(4,minmax(0,1fr));
  align-items:stretch;
}
@media (max-width:720px){
  .req-filter-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

.req-filter-form{
  display:contents; /* macht select/input/button zu Grid-Items */
}
.req-close-form{
  display:flex;
}
.req-close-form .btn{
  width:100%;
}

.req-list{
  display:grid;
  gap:12px;
  margin-top:12px;
}

details.req-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
details.req-card[open]{
  border-color:color-mix(in oklab, var(--brand) 60%, var(--border));
}

.req-summary{
  list-style:none;
  padding:10px 14px;
  cursor:pointer;
}
.req-summary::-webkit-details-marker{
  display:none;
}

/* Mobile: Datum, Brand, Meta in einer Grid-Struktur */
.req-summary-main{
  width:100%;
}

/* Ab ~700px Breite: zweispaltig */
@media (min-width:700px){
  .req-summary-main{
    display:grid;
    grid-template-columns:auto minmax(0, 1fr);
    column-gap:12px;
    row-gap:4px;
    align-items:flex-start;
  }
}

.req-date{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:12px;
  color:var(--muted);
  display:flex;
  flex-direction:column;
  flex-shrink:0;
}

.req-summary-text{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}

.req-brand{
  font-weight:600;
  font-size:15px;
  word-break:break-word;
  overflow-wrap:anywhere;
}

.req-contact-mini{
  font-size:13px;
  color:var(--muted);
  word-break:break-word;
  overflow-wrap:anywhere;
}

.req-domain-line{
  font-size:13px;
  color:var(--muted);
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  overflow-wrap:anywhere;
}

.req-summary-meta{
  margin-top:4px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
@media (min-width:640px){
  .req-summary-meta{
    margin-left:auto;
    margin-top:0;
  }
}

.pill{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  font-size:12px;
  border:1px solid #2a2f36;
  color:#cbd5e1;
}
.pill.ok{
  border-color:#16a34a;
  color:#86efac;
}

.req-body{
  border-top:1px solid #20232b;
  padding:10px 14px 12px;
  font-size:14px;
}

.req-body-grid{
  display:grid;
  gap:10px;
}
@media (min-width:720px){
  .req-body-grid{
    grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);
  }
}

.req-label{
  font-size:12px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.03em;
  margin-bottom:2px;
}

.req-block{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.req-message{
  margin-top:10px;
}
.req-message-text{
  margin-top:2px;
  font-size:13px;
  color:var(--muted);
  white-space:pre-wrap;
}

.req-actions{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

/* ===== Split-Spalte für Tenant-Formular ===== */
.req-split{
  background:var(--card);
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  min-height:50vh;
  overflow:hidden;
}

.req-split-header{
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}

.req-split-iframe{
  flex:1;
  width:100%;
  border:0;
}

/* Footer unten unter dem Login (z.B. "Noch kein Konto?") */
.login-footer{
  margin-top:auto; /* schiebt den Balken an den unteren Rand */
  padding:8px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(90deg, #0f1116, #12141a);
  border-top:1px solid var(--border);
  text-align:center;
}

.login-footer .hint{
  margin:0;
  font-size:12px;
}

/* =========================================================
   Premium-Hinweis im Status-Card
   ========================================================= */
.premium-alert{
  margin:8px 0 12px;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(127,29,29,.82);          /* dunkles Rot */
  border:1px solid rgba(248,113,113,.65);  /* helleres Rot als Rahmen */
  color:#fee2e2;                            /* fast weiß mit Rot-Ton */
  font-size:0.9rem;
  line-height:1.4;
}
.premium-alert strong{
  font-weight:600;
}
.premium-alert small{
  display:block;
  margin-top:4px;
  opacity:.8;
  font-size:0.78rem;
}

/* Setup: Passwort-Felder spätestens bei 520px untereinander */
@media (max-width: 520px) {
  .pw-row {
    flex-direction: column !important;
    flex-wrap: nowrap !important;
  }
  .pw-row > label {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
}