  :root {
    --orange:#FF6B00; --orange-dim:#cc5500;
    --dark:#0a0a0a; --dark2:#111; --dark3:#1a1a1a;
    --grey:#2a2a2a; --grey2:#333; --grey-light:#555;
    --text:#e8e8e8; --text-dim:#aaa;
    --green:#4ade80; --red:#f87171; --blue:#60a5fa; --yellow:#facc15;
  }

  body.light {
    --dark:#f0f0f0; --dark2:#ffffff; --dark3:#e8e8e8;
    --grey:#cccccc; --grey2:#bbbbbb; --grey-light:#999;
    --text:#111111; --text-dim:#555555;
  }
  body.light .admin-header { background: rgba(240,240,240,0.97); }
  body.light .admin-tabs { background: #fff; }
  body.light .login-box { box-shadow: 0 4px 24px rgba(0,0,0,0.1); }

  .theme-toggle {
    background: var(--grey); border: 1px solid var(--grey);
    border-radius: 20px; width: 44px; height: 24px;
    position: relative; cursor: pointer; transition: background 0.3s;
    flex-shrink: 0;
  }
  .theme-toggle::after {
    content: ''; position: absolute; top: 3px; left: 3px;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--orange); transition: transform 0.3s;
  }
  body.light .theme-toggle::after { transform: translateX(20px); }
  .theme-toggle-wrap {
    display: flex; align-items: center; gap: 0.5rem;
    font-family: 'Share Tech Mono', monospace;
    font-size: 0.6rem; color: var(--text-dim); letter-spacing: 0.1em;
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  body{background:var(--dark);color:var(--text);font-family:'Rajdhani',sans-serif;font-weight:500;min-height:100vh}

  /* ── LOGIN ── */
  #loginScreen{
    min-height:100vh;display:flex;align-items:center;justify-content:center;
    background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(255,107,0,0.06),transparent),var(--dark);
  }
  .login-box{
    background:var(--dark2);border:1px solid var(--grey);padding:3rem 2.5rem;width:360px;position:relative;
  }
  .login-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--orange)}
  .login-logo{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.08em;color:var(--orange);margin-bottom:.25rem}
  .login-sub{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:2rem}

  /* ── FORMS ── */
  .form-group{margin-bottom:1.2rem}
  label{display:block;font-family:'Share Tech Mono',monospace;font-size:.65rem;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;margin-bottom:.4rem}
  input[type=text],input[type=password],input[type=date],input[type=time],select,textarea{
    width:100%;background:var(--dark3);border:1px solid var(--grey);color:var(--text);
    font-family:'Rajdhani',sans-serif;font-size:.95rem;padding:.6rem .8rem;outline:none;
    transition:border-color .2s;appearance:none;
  }
  input:focus,select:focus,textarea:focus{border-color:var(--orange)}
  textarea{resize:vertical;min-height:70px}

  /* ── BUTTONS ── */
  .btn{
    display:inline-block;font-family:'Bebas Neue',sans-serif;font-size:1rem;
    letter-spacing:.12em;padding:.6rem 1.5rem;border:none;cursor:pointer;
    transition:opacity .2s,transform .15s;text-decoration:none;
  }
  .btn:hover{opacity:.85;transform:translateY(-1px)} .btn:active{transform:translateY(0)}
  .btn-primary{background:var(--orange);color:#000}
  .btn-danger{background:var(--red);color:#000}
  .btn-ghost{background:transparent;border:1px solid var(--grey);color:var(--text)}
  .btn-success{background:var(--green);color:#000}
  .btn-blue{background:var(--blue);color:#000}
  .btn-sm{font-size:.7rem;padding:.3rem .8rem}

  .login-error{color:var(--red);font-family:'Share Tech Mono',monospace;font-size:.7rem;letter-spacing:.1em;margin-top:.8rem;display:none}

  /* ── ADMIN LAYOUT ── */
  #adminScreen{display:none}
  .admin-header{
    background:var(--dark2);border-bottom:1px solid rgba(255,107,0,.25);
    padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;
    position:sticky;top:0;z-index:100;
  }
  .admin-header-title{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.08em;color:var(--orange)}
  .admin-header-title span{color:var(--text)}
  .admin-header-right{display:flex;align-items:center;gap:.6rem}
  .user-badge{
    font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);
    letter-spacing:.1em;border:1px solid var(--grey);padding:.25rem .6rem;
  }
  .role-chip{
    font-family:'Share Tech Mono',monospace;font-size:.65rem;letter-spacing:.1em;
    padding:.2rem .5rem;text-transform:uppercase;font-weight:700;
  }
  .role-owner{background:var(--orange);color:#000}
  .role-editor{background:var(--blue);color:#000}
  .role-reporter{background:var(--green);color:#000}
  .role-player{background:var(--yellow);color:#000}
  .role-taktiker{background:#a855f7;color:#fff}

  .admin-tabs{
    display:flex;border-bottom:1px solid var(--grey);background:var(--dark2);
    padding:0 2rem;overflow-x:auto;
  }
  .tab-btn{
    font-family:'Share Tech Mono',monospace;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
    color:var(--text-dim);background:none;border:none;border-bottom:2px solid transparent;
    padding:1rem 1.2rem;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;
  }
  .tab-btn:hover{color:var(--text)} .tab-btn.active{color:var(--orange);border-bottom-color:var(--orange)}
  .tab-btn[disabled]{opacity:.3;cursor:not-allowed}

  .admin-content{max-width:960px;margin:0 auto;padding:2.5rem 2rem}
  .panel{display:none} .panel.active{display:block}
  .panel-title{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:.08em;color:var(--text);margin-bottom:.3rem}
  .panel-sub{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.15em;margin-bottom:2rem}

  /* ── LOGO UPLOAD ── */
  .logo-upload-zone{
    border:1px dashed var(--grey2);padding:2rem;text-align:center;
    cursor:pointer;transition:border-color .2s;position:relative;margin-bottom:1rem;
  }
  .logo-upload-zone:hover{border-color:var(--orange)}
  .logo-upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
  .logo-upload-hint{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.12em}
  .logo-preview{max-height:100px;max-width:300px;object-fit:contain;display:block;margin:.5rem auto}

  /* ── PLAYER GRID ── */
  .player-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;margin-bottom:1rem}
  .player-admin-card{background:var(--dark2);border:1px solid var(--grey);padding:1.2rem}
  .player-admin-card-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
  .player-thumb{width:50px;height:66px;object-fit:cover;object-position:top;background:var(--dark3);border:1px solid var(--grey);flex-shrink:0}
  .player-thumb-ph{width:50px;height:66px;background:var(--dark3);border:1px solid var(--grey);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
  .player-admin-name{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;color:var(--orange);letter-spacing:.06em}
  .player-admin-sub{font-size:.78rem;color:var(--text-dim)}
  .photo-upload-area{border:1px dashed var(--grey2);padding:.8rem;text-align:center;cursor:pointer;transition:border-color .2s;margin-bottom:.8rem;position:relative}
  .photo-upload-area:hover{border-color:var(--orange)}
  .photo-upload-area input{position:absolute;inset:0;opacity:0;cursor:pointer}
  .photo-upload-text{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.1em}
  .photo-preview{width:80px;height:106px;object-fit:cover;object-position:top;margin:0 auto .5rem;display:block;border:1px solid var(--grey)}

  /* ── LAN ── */
  .lan-item{background:var(--dark2);border:1px solid var(--grey);margin-bottom:.8rem;overflow:hidden}
  .lan-item-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;cursor:pointer;gap:1rem}
  .lan-item-header:hover{background:rgba(255,107,0,.08)}
  .lan-item-name{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.06em;flex:1}
  .lan-item-date{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim)}
  .lan-matches{padding:1rem 1.2rem;border-top:1px solid var(--grey);display:none}
  .lan-matches.open{display:block}
  .match-headers{display:grid;grid-template-columns:110px 1fr 90px 100px 1fr auto;gap:.5rem;margin-bottom:.4rem;padding:0 .7rem}
  .col-label{font-family:'Share Tech Mono',monospace;font-size:.65rem;color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase}
  .match-row-admin{display:grid;grid-template-columns:110px 1fr 90px 100px 1fr auto;gap:.5rem;align-items:center;margin-bottom:.5rem;background:var(--dark3);padding:.5rem .7rem}
  .match-row-admin select,.match-row-admin input{font-size:.82rem;padding:.35rem .5rem}
  .add-match-row{display:grid;grid-template-columns:110px 1fr 90px 100px 1fr auto;gap:.5rem;align-items:center;margin-top:.8rem;background:rgba(255,107,0,.08);border:1px dashed rgba(255,107,0,.2);padding:.5rem .7rem}
  .add-lan-form{background:var(--dark2);border:1px dashed rgba(255,107,0,.3);padding:1.2rem;display:grid;grid-template-columns:1fr 150px 150px auto;gap:.8rem;align-items:end;margin-top:1rem}

  /* ── STAGE MATCH UI ── */
  .stage-admin-block{margin-bottom:2rem}
  .stage-admin-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;background:var(--dark2);border-left:3px solid var(--orange);margin-bottom:.8rem;font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:.08em}
  .match-admin-card{background:var(--dark3);border:1px solid var(--grey);padding:.8rem;margin-bottom:.6rem}
  .match-admin-card-top{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.6rem;flex-wrap:wrap}
  .maps-admin-wrap{display:flex;flex-direction:column;gap:.4rem;padding-top:.4rem;border-top:1px solid var(--grey)}
  .map-admin-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
  .map-admin-row input,.map-admin-row select{font-size:.8rem;padding:.3rem .5rem}
  .add-match-card{background:rgba(255,107,0,.08);border:1px dashed rgba(255,107,0,.25);padding:.8rem;margin-top:.4rem}

  /* ── USERS ── */
  .users-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}
  .users-table th{text-align:left;font-family:'Share Tech Mono',monospace;font-size:.65rem;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase;padding:.5rem 1rem;border-bottom:1px solid var(--grey)}
  .users-table td{padding:.8rem 1rem;border-bottom:1px solid rgba(255,255,255,.04);font-size:.9rem;vertical-align:middle}
  .users-table tr:hover td{background:rgba(255,107,0,.08)}
  .add-user-form{background:var(--dark2);border:1px dashed rgba(255,107,0,.3);padding:1.5rem;display:grid;grid-template-columns:1fr 1fr 120px auto;gap:.8rem;align-items:end}

  /* ── SETTINGS ── */
  .settings-box{background:var(--dark2);border:1px solid var(--grey);padding:1.5rem;max-width:400px}

  /* ── TOAST ── */
  #toast{
    position:fixed;bottom:2rem;right:2rem;
    font-family:'Share Tech Mono',monospace;font-size:.75rem;letter-spacing:.1em;
    padding:.8rem 1.2rem;z-index:9999;transform:translateY(100px);opacity:0;transition:all .3s;
  }
  #toast.show{transform:translateY(0);opacity:1}
  #toast.ok{background:var(--green);color:#000}
  #toast.err{background:var(--red);color:#000}

  .no-data{color:var(--text-dim);font-style:italic;font-size:.9rem;padding:1rem 0}

  /* ── SECURITY WARNING ── */
  .security-warning {
    background: rgba(248,113,113,0.08);
    border: 2px solid var(--red);
    padding: 1.2rem 1.5rem;
    margin: 1rem 2rem 0;
    display: none;
    animation: warningPulse 2s ease-in-out infinite;
  }
  @keyframes warningPulse {
    0%,100% { border-color: var(--red); box-shadow: 0 0 0 0 rgba(248,113,113,0); }
    50%      { border-color: #ff4444;   box-shadow: 0 0 12px 2px rgba(248,113,113,0.2); }
  }
  .security-warning-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 1.3rem; letter-spacing: .1em;
    color: var(--red); margin-bottom: .5rem;
    display: flex; align-items: center; gap: .6rem;
  }
  .security-warning-items {
    display: flex; flex-direction: column; gap: .4rem;
  }
  .security-warning-item {
    font-family: 'Share Tech Mono', monospace;
    font-size: .72rem; letter-spacing: .1em;
    color: var(--red); display: flex; align-items: center; gap: .5rem;
  }
  .security-warning-item a {
    color: var(--red); text-decoration: underline; cursor: pointer;
  }
  .security-warning-item a:hover { color: #ff4444; }


  /* ── LOG & CONSOLE ── */
  .log-filter-bar {
    display: flex; gap: .7rem; align-items: flex-end; flex-wrap: wrap;
    background: var(--dark2); border: 1px solid var(--grey);
    padding: 1rem; margin-bottom: 1rem;
  }
  .log-console {
    background: #080808; border: 1px solid var(--grey);
    border-left: 3px solid var(--orange);
    font-family: 'Share Tech Mono', monospace; font-size: .78rem;
    line-height: 1.65; padding: 1rem 1.2rem;
    height: 520px; overflow-y: auto;
  }
  body.light .log-console { background: #1a1a1a; }
  .log-line {
    padding: .12rem 0; border-bottom: 1px solid rgba(255,255,255,.025);
    word-break: break-all;
  }
  .log-line:hover { background: rgba(255,255,255,.04); }
  .log-ts      { color: #555; margin-right: .4em; }
  .log-role    { font-weight: bold; min-width: 9em; display: inline-block; }
  .log-user    { color: #d4d4d4; min-width: 11em; display: inline-block; }
  .log-sep     { color: #f97316; }
  .log-action  { color: #7dd3fc; }
  .log-details { color: #888; }
  .log-ip      { color: #4a4a4a; font-size: .72rem; }
  .log-placeholder { color: #444; font-family: 'Share Tech Mono', monospace; font-size: .78rem; }

  @media(max-width:700px){
    .match-row-admin,.add-match-row,.match-headers{grid-template-columns:1fr 1fr}
    .player-admin-grid{grid-template-columns:1fr}
    .add-lan-form,.add-user-form{grid-template-columns:1fr}
    .log-filter-bar{flex-direction:column;align-items:stretch}
  }
