/* MineCore Account — account.minecoregroup.de */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07090a; --bg2:#0c0f0e; --panel:#101312; --panel2:#151918;
  --border:rgba(34,197,94,.14); --border-strong:rgba(34,197,94,.32);
  --text:#edf2ef; --text-muted:#8a9690;
  --accent:#22c55e; --accent-light:#4ade80; --accent-soft:rgba(34,197,94,.14);
  --accent-glow:rgba(34,197,94,.45);
  --success:#22c55e; --danger:#ef4444;
  --radius:14px;
}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--text); line-height:1.6; min-height:100vh; overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%; display:block}
.container{max-width:1180px; margin:0 auto; padding:0 24px}

body::before{
  content:''; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(ellipse 900px 500px at 12% -8%, rgba(34,197,94,.16), transparent 60%),
    radial-gradient(ellipse 700px 500px at 100% 20%, rgba(74,222,128,.09), transparent 55%),
    var(--bg);
}
body::after{
  content:''; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.35;
  background-image:
    linear-gradient(rgba(34,197,94,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,197,94,.045) 1px, transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(ellipse 1000px 600px at 50% 0%, black, transparent 75%);
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 22px; border-radius:10px; font-size:.88rem; font-weight:700; cursor:pointer;
  border:1px solid transparent; text-decoration:none; transition:all .2s cubic-bezier(.16,1,.3,1);
  position:relative;
}
.btn-sm{padding:7px 14px; font-size:.82rem}
.btn-lg{padding:14px 28px; font-size:.95rem}
.btn-primary{background:linear-gradient(135deg,var(--accent),#0d9488); color:#04150c; box-shadow:0 6px 20px rgba(34,197,94,.35)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 10px 28px rgba(34,197,94,.5)}
.btn-danger{background:rgba(239,68,68,.14); border-color:rgba(239,68,68,.4); color:#fca5a5}
.btn-danger:hover{background:rgba(239,68,68,.22)}
.btn-ghost{background:transparent; border-color:var(--border); color:var(--text)}
.btn-ghost:hover{border-color:var(--border-strong); background:rgba(255,255,255,.03)}
.btn-outline{background:transparent; border-color:var(--border-strong); color:var(--accent-light)}
.btn-outline:hover{background:var(--accent-soft); border-color:var(--accent); transform:translateY(-2px)}
.btn:disabled{opacity:.5; cursor:not-allowed; transform:none !important}

/* Header */
.mw-header{
  position:sticky; top:0; z-index:50;
  background:rgba(7,9,10,.82); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.mw-header-inner{
  max-width:1180px; margin:0 auto; padding:13px 24px;
  display:flex; align-items:center; gap:28px; flex-wrap:wrap;
}
.mw-brand{display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0; font-weight:800}
.mw-brand img{height:34px; width:auto; border-radius:6px}
.mw-header-actions{margin-left:auto; display:flex; align-items:center; gap:10px}

.mw-user-menu{position:relative}
.mw-user-btn{
  display:flex; align-items:center; gap:8px; background:none; border:1px solid var(--border);
  border-radius:9px; padding:6px 12px 6px 6px; cursor:pointer; color:var(--text); font-size:.85rem; font-weight:600;
  transition:border-color .15s;
}
.mw-user-btn:hover{border-color:var(--border-strong)}
.mw-avatar{
  width:26px; height:26px; border-radius:7px; background:linear-gradient(135deg,var(--accent),#0d9488); color:#04150c;
  display:flex; align-items:center; justify-content:center; font-size:.8rem; font-weight:700;
}
.mw-user-dropdown{
  position:absolute; right:0; top:calc(100% + 8px); min-width:180px;
  background:var(--panel2); border:1px solid var(--border); border-radius:10px; padding:8px;
  display:none; box-shadow:0 16px 40px rgba(0,0,0,.5);
}
.mw-user-dropdown.show{display:block}
.mw-user-dropdown a{display:block; padding:8px 10px; border-radius:6px; font-size:.85rem; text-decoration:none; color:var(--text)}
.mw-user-dropdown a:hover{background:rgba(255,255,255,.05)}

/* Forms (login/register) */
.mw-auth-wrap{min-height:calc(100vh - 66px); display:flex; align-items:center; justify-content:center; padding:40px 20px}
.mw-auth-card{
  width:100%; max-width:420px; background:linear-gradient(180deg, var(--panel), var(--panel2));
  border:1px solid var(--border); border-radius:var(--radius); padding:38px 34px;
  box-shadow:0 24px 60px rgba(0,0,0,.4);
}
.mw-auth-card h1{font-size:1.4rem; font-weight:800; margin-bottom:6px; text-align:center}
.mw-auth-card .sub{font-size:.85rem; color:var(--text-muted); text-align:center; margin-bottom:26px}
.form-group{margin-bottom:16px}
.form-label{display:block; font-size:.8rem; font-weight:600; margin-bottom:6px; color:var(--text-muted)}
.form-control{
  width:100%; background:var(--bg2); border:1px solid var(--border); border-radius:9px;
  padding:11px 14px; color:var(--text); font-size:.9rem; transition:border-color .15s;
  font-family:inherit;
}
.form-control:focus{outline:none; border-color:var(--accent)}
.mw-auth-alt{text-align:center; font-size:.85rem; color:var(--text-muted); margin-top:18px}
.mw-auth-alt a{color:var(--accent-light); text-decoration:none; font-weight:600}
.alert{padding:10px 13px; border-radius:8px; font-size:.82rem; margin-bottom:14px}
.alert-danger{background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3); color:#fca5a5}
.alert-success{background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.3); color:#86efac}
.alert-warn{background:rgba(234,179,8,.1); border:1px solid rgba(234,179,8,.3); color:#fbd88a}

/* Security code display */
.mw-code-box{
  background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:20px;
  text-align:center; font-size:1.2rem; font-weight:700; letter-spacing:1px; margin:20px 0;
  color:var(--accent-light); font-family:monospace; word-break:break-all;
}

/* Toast */
.toast-container{position:fixed; bottom:20px; right:20px; z-index:999; display:flex; flex-direction:column; gap:8px}
.toast{
  background:var(--panel2); border:1px solid var(--border); border-radius:9px; padding:12px 18px;
  font-size:.85rem; box-shadow:0 16px 36px rgba(0,0,0,.5);
}
.toast-success{border-color:rgba(34,197,94,.4)}
.toast-error{border-color:rgba(239,68,68,.4)}

/* === Dashboard layout === */
.acc-shell{max-width:1180px; margin:0 auto; padding:32px 24px 80px; display:grid; grid-template-columns:220px 1fr; gap:32px}
.acc-sidebar{display:flex; flex-direction:column; gap:4px}
.acc-sidebar a{
  display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:9px; font-size:.88rem;
  font-weight:600; color:var(--text-muted); text-decoration:none; transition:all .15s;
}
.acc-sidebar a:hover{background:var(--panel); color:var(--text)}
.acc-sidebar a.active{background:var(--accent-soft); color:var(--accent-light)}
.acc-main{min-width:0}
.acc-main h1{font-size:1.6rem; font-weight:800; margin-bottom:6px}
.acc-main .sub{color:var(--text-muted); font-size:.9rem; margin-bottom:28px}
@media(max-width:820px){
  .acc-shell{grid-template-columns:1fr}
  .acc-sidebar{flex-direction:row; flex-wrap:wrap; gap:8px}
}

/* Cards */
.acc-card{
  background:var(--panel); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px 26px; margin-bottom:20px;
}
.acc-card h3{font-size:1rem; font-weight:700; margin-bottom:4px}
.acc-card .desc{font-size:.85rem; color:var(--text-muted); margin-bottom:18px}

/* Stat grid (Dashboard-Übersicht) */
.acc-stat-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:24px}
.acc-stat{background:var(--panel); border:1px solid var(--border); border-radius:12px; padding:18px 20px}
.acc-stat .lbl{font-size:.75rem; color:var(--text-muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:.05em}
.acc-stat .val{font-size:1.15rem; font-weight:800}

/* Status badges */
.acc-badge{display:inline-flex; align-items:center; gap:6px; font-size:.75rem; font-weight:700; padding:4px 10px; border-radius:999px}
.acc-badge.ok{background:rgba(34,197,94,.14); color:var(--accent-light)}
.acc-badge.warn{background:rgba(234,179,8,.14); color:#fbd88a}
.acc-badge.danger{background:rgba(239,68,68,.14); color:#fca5a5}
.acc-badge .dot{width:6px; height:6px; border-radius:50%; background:currentColor}

/* Toggle switch (Benachrichtigungen) */
.acc-toggle-row{display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--border)}
.acc-toggle-row:last-child{border-bottom:none}
.acc-toggle-row .t{font-size:.88rem; font-weight:600}
.acc-toggle-row .d{font-size:.78rem; color:var(--text-muted)}
.acc-switch{position:relative; width:42px; height:24px; flex-shrink:0}
.acc-switch input{opacity:0; width:0; height:0}
.acc-switch .slider{position:absolute; inset:0; background:var(--bg2); border:1px solid var(--border); border-radius:999px; cursor:pointer; transition:.2s}
.acc-switch .slider::before{content:''; position:absolute; width:16px; height:16px; left:3px; top:2.5px; background:var(--text-muted); border-radius:50%; transition:.2s}
.acc-switch input:checked + .slider{background:var(--accent-soft); border-color:var(--accent)}
.acc-switch input:checked + .slider::before{transform:translateX(18px); background:var(--accent-light)}

/* List rows (Sessions, Käufe, Tickets) */
.acc-row{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0; border-bottom:1px solid var(--border)}
.acc-row:last-child{border-bottom:none}
.acc-row .main{font-size:.9rem; font-weight:600}
.acc-row .meta{font-size:.78rem; color:var(--text-muted); margin-top:2px}
.acc-empty{text-align:center; padding:30px 0; color:var(--text-muted); font-size:.88rem}

/* Service connection list (Dashboard) */
.acc-service-list{display:flex; flex-direction:column; gap:10px}
.acc-service{display:flex; align-items:center; gap:10px; font-size:.88rem}
.acc-service .ico{width:22px; height:22px; border-radius:6px; display:flex; align-items:center; justify-content:center; background:var(--accent-soft); color:var(--accent-light); font-size:.75rem; flex-shrink:0}
