*{margin:0;padding:0;box-sizing:border-box}
:root{--primary-cyan:#00d9ff;--secondary-cyan:#00fff9;--dark-bg:#0a1628;--darker-bg:#050d1a;--card-bg:rgba(10,30,50,.85);--border-cyan:#00d9ff;--glow-cyan:rgba(0,217,255,.5);--text-cyan:#00fff9;--text-white:#e8f4f8;--text-muted:#7a9eb5}
html,body{min-height:100%;width:100%;overflow-x:hidden}
body{font-family:'Segoe UI','Roboto','Arial',sans-serif;background:linear-gradient(180deg,var(--darker-bg) 0%,var(--dark-bg) 100%);background-attachment:fixed;min-height:100vh;padding:15px;display:flex;flex-direction:column;justify-content:center;align-items:center;color:var(--text-white);position:relative}
.background-animation{position:fixed;width:100%;height:100%;overflow:hidden;z-index:0;top:0;left:0;background-image:linear-gradient(rgba(0,217,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,217,255,.03) 1px,transparent 1px);background-size:50px 50px;animation:grid-move 20s linear infinite}
@keyframes grid-move{0%{background-position:0 0}100%{background-position:50px 50px}}
.floating-shape{position:absolute;border:2px solid var(--border-cyan);background:radial-gradient(circle,rgba(0,217,255,.1),transparent);animation:float-glow 8s infinite ease-in-out;box-shadow:0 0 20px var(--glow-cyan),inset 0 0 20px rgba(0,217,255,.1)}
.shape1{width:80px;height:80px;left:5%;top:15%;border-radius:10px;transform:rotate(45deg);animation-delay:0s}
.shape2{width:100px;height:100px;right:10%;top:50%;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);animation-delay:2s}
.shape3{width:60px;height:60px;left:75%;top:25%;border-radius:50%;animation-delay:4s}
.shape4{width:90px;height:90px;left:20%;bottom:15%;clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);animation-delay:1s}
@keyframes float-glow{0%,100%{transform:translateY(0) rotate(0);opacity:.3}50%{transform:translateY(-30px) rotate(180deg);opacity:.6}}
.container{background:var(--card-bg);border:2px solid var(--border-cyan);border-radius:15px;padding:30px 20px;box-shadow:0 0 30px var(--glow-cyan),inset 0 0 30px rgba(0,217,255,.05);max-width:500px;width:100%;position:relative;z-index:1;backdrop-filter:blur(10px);animation:slideUp .6s ease-out}
.container.wide{max-width:100%;background:transparent;border:none;box-shadow:none;backdrop-filter:none;padding:0}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.container::before,.container::after{content:'';position:absolute;width:20px;height:20px;border:2px solid var(--primary-cyan)}
.container::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.container::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.emoji{font-size:50px;text-align:center;margin-bottom:15px;filter:drop-shadow(0 0 10px var(--glow-cyan));animation:pulse-glow 2s infinite}
@keyframes pulse-glow{0%,100%{transform:scale(1);filter:drop-shadow(0 0 10px var(--glow-cyan))}50%{transform:scale(1.05);filter:drop-shadow(0 0 20px var(--primary-cyan))}}
.logo{font-size:48px;font-weight:800;color:var(--primary-cyan);margin-bottom:8px;text-align:center;text-transform:uppercase;letter-spacing:4px;text-shadow:0 0 20px var(--glow-cyan),0 0 40px var(--glow-cyan)}
.subtitle{color:var(--text-muted);font-size:14px;margin-bottom:25px;text-align:center;font-weight:400;text-transform:uppercase;letter-spacing:2px}
.btn{width:100%;padding:14px 20px;background:rgba(0,217,255,.1);color:var(--text-cyan);border:2px solid var(--border-cyan);border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:2px;position:relative;overflow:hidden;box-shadow:0 0 20px rgba(0,217,255,.2)}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,249,.3),transparent);transition:left .5s}
.btn:hover:not(:disabled)::before{left:100%}
.btn:hover:not(:disabled){background:rgba(0,217,255,.2);box-shadow:0 0 30px var(--glow-cyan),inset 0 0 20px rgba(0,217,255,.2);transform:translateY(-2px)}
.btn:active:not(:disabled){transform:translateY(0)}
.btn:disabled{opacity:.3;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted)}
.btn-secondary{background:rgba(0,255,249,.15);border-color:var(--secondary-cyan);color:var(--secondary-cyan)}
.btn-danger{background:rgba(255,59,92,.15);border-color:#ff3b5c;color:#ff6b8a;box-shadow:0 0 20px rgba(255,59,92,.3)}
.btn-danger:hover:not(:disabled){background:rgba(255,59,92,.25);box-shadow:0 0 30px rgba(255,59,92,.5)}
.btn-vote{padding:8px 16px;background:rgba(0,217,255,.15);color:var(--text-cyan);border:2px solid var(--border-cyan);border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:13px;margin-top:10px;text-transform:uppercase;letter-spacing:1px}
.btn-vote:hover:not(:disabled){background:rgba(0,217,255,.3);box-shadow:0 0 20px var(--glow-cyan)}
.form-group{margin-bottom:20px}
label{display:block;color:var(--text-cyan);font-weight:600;margin-bottom:8px;font-size:12px;text-transform:uppercase;letter-spacing:2px}
input[type="text"]{width:100%;padding:12px 16px;border:2px solid rgba(0,217,255,.3);border-radius:10px;font-size:15px;transition:all .3s ease;background:rgba(10,30,50,.5);color:var(--text-white);font-weight:500}
input[type="text"]::placeholder{color:var(--text-muted)}
input[type="text"]:focus{outline:none;border-color:var(--border-cyan);background:rgba(10,30,50,.8);box-shadow:0 0 20px rgba(0,217,255,.3)}
#gameCode{text-transform:uppercase;text-align:center;letter-spacing:4px;font-size:18px;font-weight:700}
.divider{text-align:center;margin:25px 0;color:var(--text-muted);font-weight:600;position:relative;font-size:12px;letter-spacing:2px}
.divider::before,.divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:linear-gradient(90deg,transparent,var(--border-cyan),transparent)}
.divider::before{left:0}.divider::after{right:0}
.error{color:#ff6b8a;font-size:13px;margin-top:15px;padding:12px;background:rgba(255,59,92,.1);border:1px solid rgba(255,59,92,.3);border-radius:8px;display:none;text-align:center}
body.lobby{display:flex;padding:20px 15px}
.header{text-align:center;color:var(--text-white);margin-bottom:25px}
.header h1{font-size:42px;margin-bottom:10px;text-shadow:0 0 30px var(--glow-cyan);font-weight:800;letter-spacing:3px;color:var(--primary-cyan)}
.username-display{background:rgba(0,217,255,.1);padding:10px 20px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;border:2px solid var(--border-cyan);backdrop-filter:blur(10px);cursor:pointer;transition:all .3s ease;box-shadow:0 0 20px rgba(0,217,255,.2)}
.username-display:hover{background:rgba(0,217,255,.2);box-shadow:0 0 30px var(--glow-cyan);transform:translateY(-2px)}
.edit-icon{font-size:14px;opacity:.8}
.card{background:var(--card-bg);border:2px solid var(--border-cyan);border-radius:15px;padding:25px 20px;box-shadow:0 0 30px rgba(0,217,255,.2),inset 0 0 30px rgba(0,217,255,.05);margin-bottom:20px;position:relative}
.card::before,.card::after{content:'';position:absolute;width:15px;height:15px;border:2px solid var(--primary-cyan)}
.card::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.card::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.code-display{background:linear-gradient(135deg,rgba(0,217,255,.15),rgba(0,255,249,.1));padding:25px;border-radius:12px;text-align:center;margin-bottom:25px;border:2px solid var(--border-cyan);box-shadow:0 0 30px var(--glow-cyan),inset 0 0 30px rgba(0,217,255,.1);position:relative;overflow:hidden}
.code-label{color:var(--text-cyan);font-size:12px;margin-bottom:10px;text-transform:uppercase;letter-spacing:3px;font-weight:600}
.code-value{font-size:48px;font-weight:800;color:var(--text-white);letter-spacing:8px;text-shadow:0 0 20px var(--glow-cyan);cursor:pointer;transition:all .3s ease;position:relative;font-family:'Courier New',monospace}
.code-value:hover{transform:scale(1.05);text-shadow:0 0 30px var(--primary-cyan)}
.code-hint{color:var(--text-muted);font-size:11px;margin-top:10px;text-transform:uppercase;letter-spacing:1px}
.lobby-section{margin-bottom:25px}
.section-title{color:var(--text-cyan);font-size:18px;margin-bottom:15px;display:flex;align-items:center;gap:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.players-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.player-card{background:rgba(10,30,50,.6);padding:16px 12px;border-radius:12px;text-align:center;border:2px solid rgba(0,217,255,.3);transition:all .3s ease;box-shadow:0 0 15px rgba(0,217,255,.1);position:relative}
.player-card:hover{transform:translateY(-3px);border-color:var(--border-cyan);box-shadow:0 0 25px var(--glow-cyan)}
.player-card.host{border-color:var(--primary-cyan);background:linear-gradient(135deg,rgba(0,217,255,.2),rgba(0,255,249,.1))}
.player-card.eliminated{border-color:rgba(255,59,92,.5);background:rgba(255,59,92,.1);opacity:.5}
.player-name{font-weight:700;font-size:16px;margin-bottom:5px;display:flex;align-items:center;justify-content:center;gap:5px;color:var(--text-white)}
.player-status{color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.vote-count{color:var(--text-cyan);font-weight:600;margin-top:8px;font-size:13px}

/* WORD AREA */
.word-display{background:linear-gradient(135deg,rgba(0,217,255,.2),rgba(0,255,249,.15));color:var(--text-white);padding:40px 20px;border-radius:12px;text-align:center;margin-bottom:25px;border:2px solid var(--border-cyan);box-shadow:0 0 40px var(--glow-cyan),inset 0 0 40px rgba(0,217,255,.1);position:relative;min-height:120px}
.word-display::before{content:'';position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(0,255,249,.12) 0%,transparent 60%);pointer-events:none;animation:rotate-slow 8s linear infinite}
.word-title{font-size:14px;letter-spacing:2px;text-transform:uppercase;color:var(--text-cyan);margin-bottom:10px}
.word{font-size:42px;font-weight:800;text-shadow:0 0 30px var(--glow-cyan);letter-spacing:3px;color:var(--text-white);word-break:break-word}

/* EYE BUTTON – FIXED TOP RIGHT + ALWAYS CLICKABLE */
.word-display .eye-top{position:absolute;top:8px;right:8px;z-index:5;cursor:pointer;pointer-events:auto}
.icon-btn{background:transparent;border:2px solid rgba(0,217,255,.3);border-radius:10px;padding:6px}
.icon{display:inline-block}

#lobbyView,#gameView{display:none}
.waiting-animation{text-align:center;padding:30px;color:var(--text-muted)}
.button-group{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tooltip{position:relative;display:inline-block}
.tooltip .tooltiptext{visibility:visible;background:rgba(10,30,50,.9);color:#fff;text-align:center;border-radius:6px;padding:5px 8px;position:absolute;z-index:1;bottom:-30px;left:50%;transform:translateX(-50%);opacity:.8;font-size:12px;border:1px solid rgba(0,217,255,.2)}
.word-display::before{
  animation: none !important;
  display: none; /* optional: blendet das Element komplett aus */
}

/* --- Legal Footer (nur Startseite) --- */
.footer-legal{
  position: fixed;           /* immer ganz unten sichtbar */
  left: 0; right: 0; bottom: 14px;
  text-align: center;
  z-index: 2;                /* über der Hintergrundanimation */
  font-size: 13px;
  color: var(--text-muted);
  pointer-events: auto;
}

.footer-legal a{
  color: var(--text-cyan);
  text-decoration: none;
  border-bottom: 1px dashed rgba(0,217,255,.35);
  padding: 2px 4px;
  transition: all .25s ease;
}

.footer-legal a:hover{
  color: var(--text-white);
  border-bottom-color: rgba(0,217,255,.7);
  text-shadow: 0 0 10px var(--glow-cyan);
}

.footer-legal .sep{
  margin: 0 8px;
  color: var(--text-muted);
}

/* Sicherheit: in der Lobby (Spielseite) KEIN fester Footer */
body.lobby .footer-legal{ display: none; }

/* ==== Info-Dropdown auf der Startseite ==== */
.info-dropdown{
  width:100%;
  margin:16px 0 24px;
  background: var(--card-bg);
  border: 2px solid var(--border-cyan);
  border-radius: 12px;
  overflow:hidden;
  box-shadow: 0 0 20px var(--glow-cyan), inset 0 0 12px rgba(0,217,255,.06);
}

.info-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  cursor:pointer;
  font-weight:700;
  color: var(--text-white);
  user-select:none;
}

.info-header:hover{
  background: rgba(0,0,0,.12);
}

.info-arrow{
  transition: transform .25s ease;
  display:inline-block;
}

.info-arrow.open{
  transform: rotate(180deg);
}

.info-content{
  padding: 12px 16px 16px;
  color: var(--text-white);
  border-top: 1px solid rgba(255,255,255,.08);
}

.info-content p{ margin: 0 0 10px 0; }
.info-content ul{
  margin: 6px 0 0 18px;
  padding:0;
}
.info-content li{
  margin: 6px 0;
  color: var(--text-muted);
}
/* ==== CHAT CONTAINER STYLES - FÃœGE DIES IN style.css EIN ==== */

.chat-container {
  background: var(--card-bg);
  border: 2px solid var(--border-cyan);
  border-radius: 15px;
  margin-bottom: 20px;
  overflow: hidden;
  box-shadow: 0 0 30px rgba(0,217,255,.2), inset 0 0 30px rgba(0,217,255,.05);
}

.chat-header {
  background: linear-gradient(135deg, rgba(0,217,255,.2), rgba(0,255,249,.1));
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: var(--text-cyan);
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 14px;
  border-bottom: 2px solid rgba(0,217,255,.3);
}

.chat-messages {
  height: 300px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 15px;
  background: rgba(5,13,26,.6);
  scroll-behavior: smooth;
}

/* Custom Scrollbar */
.chat-messages::-webkit-scrollbar {
  width: 8px;
}

.chat-messages::-webkit-scrollbar-track {
  background: rgba(0,0,0,.3);
  border-radius: 4px;
}

.chat-messages::-webkit-scrollbar-thumb {
  background: rgba(0,217,255,.3);
  border-radius: 4px;
  transition: all .3s ease;
}

.chat-messages::-webkit-scrollbar-thumb:hover {
  background: rgba(0,217,255,.5);
}

.chat-welcome {
  text-align: center;
  color: var(--text-muted);
  font-size: 14px;
  padding: 20px;
  font-style: italic;
}

.chat-message {
  margin-bottom: 12px;
  padding: 10px 12px;
  background: rgba(10,30,50,.5);
  border-left: 3px solid rgba(0,217,255,.4);
  border-radius: 8px;
  animation: slideInMessage 0.3s ease-out;
}

.chat-message-own {
  background: rgba(0,217,255,.15);
  border-left-color: var(--primary-cyan);
}

@keyframes slideInMessage {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.chat-message-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 5px;
}

.chat-username {
  font-weight: 700;
  color: var(--text-cyan);
  font-size: 13px;
}

.chat-time {
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'Courier New', monospace;
}

.chat-message-text {
  color: var(--text-white);
  font-size: 14px;
  line-height: 1.4;
  word-wrap: break-word;
}

.chat-input-wrapper {
  display: flex;
  gap: 8px;
  padding: 12px;
  background: rgba(5,13,26,.8);
  border-top: 2px solid rgba(0,217,255,.3);
}

.chat-input {
  flex: 1;
  padding: 10px 14px;
  border: 2px solid rgba(0,217,255,.3);
  border-radius: 8px;
  font-size: 14px;
  background: rgba(10,30,50,.6);
  color: var(--text-white);
  transition: all .3s ease;
}

.chat-input::placeholder {
  color: var(--text-muted);
}

.chat-input:focus {
  outline: none;
  border-color: var(--border-cyan);
  background: rgba(10,30,50,.9);
  box-shadow: 0 0 15px rgba(0,217,255,.2);
}

.chat-send-btn {
  padding: 10px 16px;
  background: rgba(0,217,255,.2);
  color: var(--text-cyan);
  border: 2px solid var(--border-cyan);
  border-radius: 8px;
  cursor: pointer;
  transition: all .3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
}

.chat-send-btn:hover:not(:disabled) {
  background: rgba(0,217,255,.35);
  box-shadow: 0 0 20px var(--glow-cyan);
  transform: translateY(-2px);
}

.chat-send-btn:active:not(:disabled) {
  transform: translateY(0);
}

.chat-send-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.chat-send-btn svg {
  transition: transform .2s ease;
}

.chat-send-btn:hover:not(:disabled) svg {
  transform: translateX(2px);
}

/* Responsive */
@media (max-width: 640px) {
  .chat-messages {
    height: 250px;
  }
  
  .chat-input {
    font-size: 13px;
  }
  
  .chat-message-text {
    font-size: 13px;
  }
}