/* Rebuilt, clean stylesheet */
/* Theme variables */
:root {--gold:#d4af37;--gold-soft:#b8922d;--bg-top:#1a1a1a;--bg-bottom:#000;--bg-panel:rgba(15,15,15,.96);--danger:#ff6961;--success:#3ddc97;--focus-ring:0 0 0 2px rgba(212,175,55,.35);--panel-shift-x:0}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
html,body{height:100%;}
*{box-sizing:border-box}
*::before,*::after{box-sizing:inherit}
body{margin:0;background:linear-gradient(to bottom,var(--bg-top),var(--bg-bottom));color:var(--gold);font-family:Georgia,'Times New Roman',Times,serif;display:flex;flex-direction:column;justify-content:center;align-items:center;-webkit-font-smoothing:antialiased}
/* Buttons */
.login-button{position:absolute;top:20px;right:30px;background:transparent;border:1px solid var(--gold);color:var(--gold);padding:8px 16px;font-size:14px;cursor:pointer;transition:all .3s ease;z-index:50;letter-spacing:.5px}
.login-button:hover{background:var(--gold);color:#000}
.login-button:focus-visible,.lang-toggle:focus-visible,.login-actions button:focus-visible,.lang-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}
/* Language Dropdown */
.lang-wrapper{position:fixed;top:10px;left:10px;z-index:40}
.lang-toggle{background:#111;color:var(--gold);border:1px solid var(--gold);padding:8px 14px 8px 12px;font-size:14px;cursor:pointer;font-family:Georgia,'Times New Roman',Times,serif;display:flex;align-items:center;gap:6px;border-radius:4px;transition:background .3s,color .3s}
.lang-toggle:hover,.lang-toggle:focus{background:#1d1d1d}
.lang-toggle .chevron{font-size:11px;line-height:1;transition:transform .3s ease}
.lang-wrapper.open .lang-toggle .chevron{transform:rotate(180deg)}
.lang-menu{list-style:none;margin:4px 0 0;padding:4px 0;background:#111;border:1px solid var(--gold);position:absolute;min-width:140px;top:100%;left:0;border-radius:4px;display:none;opacity:0;transform:translateY(-4px);transition:opacity .25s ease,transform .25s ease}
.lang-menu.open{display:block;opacity:1;transform:translateY(0)}
.lang-item{padding:6px 14px;cursor:pointer;color:var(--gold);font-size:14px;user-select:none}
.lang-item:hover,.lang-item.active{background:#1f1f1f}
/* Logo & Tagline */
.logo{max-width:400px;width:80%;margin-bottom:20px}
.tagline{font-size:16px;letter-spacing:1px;text-align:center;color:#aaa;font-style:italic}
/* Login Panel */
.login-panel{position:absolute;top:70px;right:30px;width:clamp(260px,32vw,340px);max-width:90vw;background:var(--bg-panel);border:1px solid var(--gold);border-radius:14px;padding:20px 22px 22px;box-shadow:0 10px 34px -4px rgba(0,0,0,.7),0 0 0 1px rgba(212,175,55,.08);backdrop-filter:blur(6px);z-index:55;max-height:calc(100dvh - 120px);overflow-y:auto;-webkit-overflow-scrolling:touch;opacity:0;transform:translateX(var(--panel-shift-x)) translateY(-8px) scale(.96);transition:opacity .35s ease,transform .45s cubic-bezier(.4,.14,.3,1);pointer-events:none;visibility:hidden}
.login-panel.open{opacity:1;transform:translateX(var(--panel-shift-x)) translateY(0) scale(1);pointer-events:auto;visibility:visible}
.login-panel h3{margin:0 0 14px;font-size:18px;letter-spacing:1px;color:var(--gold);text-align:center}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;letter-spacing:1px;margin-bottom:4px;color:var(--gold);text-transform:uppercase}
.form-group input[type=text],.form-group input[type=password]{width:100%;padding:8px 12px;background:#000;border:1px solid #735f19;border-radius:6px;color:var(--gold);font-size:14px;outline:none;transition:border-color .25s}
.form-group input[type=text]:focus,.form-group input[type=password]:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(212,175,55,.15)}
.login-actions{display:flex;gap:10px;margin-top:4px}
.login-actions button{flex:1;font-size:14px;padding:8px 10px;border-radius:6px;border:1px solid var(--gold);cursor:pointer;background:transparent;color:var(--gold);transition:all .3s}
.login-actions button:hover{background:var(--gold);color:#000}
.login-actions button.submit{background:var(--gold);color:#000;font-weight:600}
.close-x{position:absolute;top:6px;right:10px;color:var(--gold);background:transparent;border:none;font-size:18px;line-height:1;cursor:pointer}
.close-x:hover{color:#fff}
.login-error{color:var(--danger);font-size:12px;margin-top:4px;min-height:16px}
/* Footer */
.footer-impressum{position:fixed;left:0;right:0;bottom:0;text-align:center;z-index:40;padding-bottom:env(safe-area-inset-bottom,8px)}
.impressum-link{color:#aaa;font-size:13px;text-decoration:none;opacity:.7;transition:opacity .2s,color .2s}
.impressum-link:hover{color:var(--gold);opacity:1;text-decoration:underline}
/* Backdrop overlay */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);opacity:0;transition:opacity .35s ease;pointer-events:none;z-index:50}
.backdrop.show{opacity:1;pointer-events:auto}
body.modal-open{overflow:hidden;touch-action:none}
/* Animations */
@keyframes fadeSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}} /* retained for legacy; panel now uses transitions */
/* Responsive */
@media (max-width:600px){.login-panel{position:fixed;top:60px;left:50%;right:auto;--panel-shift-x:-50%;width:calc(100vw - 32px);max-width:420px;padding:18px 20px 20px;border-radius:14px;max-height:calc(100dvh - 80px);overscroll-behavior:contain}.login-button{position:fixed;top:10px;right:10px;font-size:15px;padding:10px 18px}.logo{max-width:65vw;width:65vw;margin-bottom:12px}.tagline{font-size:14px;padding:0 10px}}
@media (max-width:400px){.login-panel{padding:12px 2vw 14px 2vw}.logo{max-width:98vw;width:98vw}.tagline{font-size:13px}}
