:root{--color-bg: #0f1117;--color-bg-elevated: #1a1d27;--color-bg-card: #222639;--color-bg-input: #2a2e42;--color-surface: #2a2e42;--color-border: #363b52;--color-border-focus: #7c6bf0;--color-text: #e8e9ed;--color-text-muted: #8b8fa3;--color-text-subtle: #5c6178;--color-primary: #7c6bf0;--color-primary-hover: #9485f5;--color-primary-glow: rgba(124, 107, 240, .25);--color-accent: #f06b9e;--color-success: #34d399;--color-error: #f06b6b;--color-warning: #f0b06b;--gradient-bg: linear-gradient(135deg, #0f1117 0%, #1a1535 50%, #0f1117 100%);--gradient-card: linear-gradient(145deg, #222639 0%, #1a1d27 100%);--gradient-primary: linear-gradient(135deg, #7c6bf0 0%, #a78bfa 50%, #f06b9e 100%);--gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(124, 107, 240, .15) 0%, transparent 60%);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 30px rgba(124, 107, 240, .2);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background:var(--gradient-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%;display:flex;flex-direction:column}a{color:var(--color-primary);text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font-family:inherit;color:inherit;border:none;outline:none;background:none}.loading-text,.empty-text{color:var(--color-text-subtle);font-size:var(--font-size-sm);text-align:center;padding:var(--space-lg)}.light-theme{--color-bg: #f5f5f7;--color-bg-elevated: #ffffff;--color-bg-card: #ffffff;--color-bg-input: #f0f0f3;--color-surface: #eeeef0;--color-border: #d8d8dc;--color-border-focus: #7c6bf0;--color-text: #1a1a1e;--color-text-muted: #6b6b78;--color-text-subtle: #9b9ba8;--gradient-bg: linear-gradient(135deg, #f5f5f7 0%, #ededf5 50%, #f5f5f7 100%);--gradient-card: linear-gradient(145deg, #ffffff 0%, #f8f8fa 100%)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(30px,-30px)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.input-group{position:relative}.input-group label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.input-group input{width:100%;padding:.85rem 1rem;background:var(--color-bg-input);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input-group input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-glow)}.input-group input::placeholder{color:var(--color-text-subtle)}.btn-primary{width:100%;padding:.85rem;background:var(--gradient-primary);color:#fff;font-size:var(--font-size-base);font-weight:600;border-radius:var(--radius-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md),0 0 20px var(--color-primary-glow)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary.loading{color:transparent}.btn-primary.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.btn-logout{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);padding:.4rem .8rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:all var(--transition-fast)}.btn-logout:hover{color:var(--color-error);border-color:var(--color-error);background:#f06b6b1a}.toggle{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:44px;height:24px;border-radius:12px;background:var(--color-surface);border:2px solid var(--color-border);position:relative;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.toggle:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:var(--color-text-muted);top:2px;left:2px;transition:all var(--transition-fast)}.toggle:checked{background:var(--color-primary);border-color:var(--color-primary)}.toggle:checked:after{background:#fff;left:22px}.vote-btn{padding:.85rem;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:700;color:#fff;transition:all var(--transition-fast);position:relative;overflow:hidden}.vote-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.vote-btn:active{transform:translateY(0)}.vote-btn.voted{animation:pulse .4s ease}.vote-btn.selected{box-shadow:0 0 0 3px #ffffff80,var(--shadow-md);transform:scale(1.03)}.rate-geil{background:linear-gradient(135deg,#22c55e,#16a34a)}.rate-gut{background:linear-gradient(135deg,#3b82f6,#2563eb)}.rate-geht{background:linear-gradient(135deg,#eab308,#ca8a04)}.rate-scheisse{background:linear-gradient(135deg,#ef4444,#dc2626)}.nav-btn{flex:1;padding:.6rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);transition:all var(--transition-fast)}.nav-btn:hover{background:var(--color-bg-card);border-color:var(--color-primary);color:var(--color-primary)}.nav-shuffle{background:var(--gradient-primary);color:#fff;border-color:transparent}.nav-shuffle:hover{color:#fff;box-shadow:var(--shadow-sm);opacity:.9}.type-btn{flex:1;padding:.5rem;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);transition:flex .25s ease,background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.type-btn.active{flex:2;background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-sm)}.type-btn:hover:not(.active){background:var(--color-bg-card);color:var(--color-text)}.tag-chip{font-size:var(--font-size-xs);padding:.3rem .7rem;border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.tag-chip:hover{background:var(--color-bg-card);color:var(--color-text);border-color:var(--color-primary)}.tag-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.quote-tag-chip{font-size:var(--font-size-xs);padding:.25rem .75rem;border-radius:var(--radius-full);background:#7c6bf026;color:var(--color-primary);border:1px solid rgba(124,107,240,.3);font-weight:500}.tag-search{width:100%;padding:.6rem .8rem;background:var(--color-bg-input);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text);transition:border-color var(--transition-fast)}.tag-search:focus{border-color:var(--color-border-focus);outline:none}.tag-search::placeholder{color:var(--color-text-subtle)}#search-id::-webkit-outer-spin-button,#search-id::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}#search-id{-moz-appearance:textfield}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:var(--space-md) var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:var(--font-size-sm);animation:fadeSlideIn .3s ease-out;max-width:320px}.toast.success{border-color:#34d39966;color:var(--color-success)}.toast.error{border-color:#f06b6b66;color:var(--color-error)}.login-error{background:#f06b6b1a;border:1px solid rgba(240,107,107,.3);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);text-align:center;animation:shake .4s ease-out}.app-shell{height:100%;display:flex;flex-direction:column}.app-body{flex:1;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);flex-shrink:0}.header-left{display:flex;align-items:baseline;gap:var(--space-md)}.app-header .brand{font-size:var(--font-size-xl);font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted)}.header-right{display:flex;align-items:center;gap:var(--space-md)}.app-header .user-info{display:flex;align-items:center;gap:var(--space-sm)}.app-header .username{font-weight:600;color:var(--color-text)}.app-header .role-badge{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;padding:.2rem .6rem;border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-muted);letter-spacing:.05em}.app-header .role-badge.admin{background:#34d39926;color:var(--color-success)}.vote-layout{display:grid;grid-template-columns:var(--leaderboard-width, 280px) 1fr 300px;gap:var(--space-md);height:100%;padding:var(--space-md);overflow:hidden;transition:grid-template-columns .25s ease}.sidebar{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);overflow-y:auto}.sidebar-title{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-lg);color:var(--color-text)}.sidebar-title--toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.sidebar-collapse-arrow{font-size:var(--font-size-sm);color:var(--color-text-muted);transition:transform var(--transition-fast)}.leaderboard-list--hidden{display:none}.sidebar-left.sidebar--collapsed{overflow:hidden;padding:var(--space-md) 0;display:flex;align-items:center;justify-content:center}.sidebar-left.sidebar--collapsed .leaderboard-list{display:none}.sidebar-left.sidebar--collapsed .sidebar-title--toggle{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);margin-bottom:0;font-size:var(--font-size-sm);white-space:nowrap}.sidebar-left.sidebar--collapsed .sidebar-collapse-arrow{display:none}.settings-group{display:flex;flex-direction:column;gap:var(--space-sm)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0;font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer}.tag-search-wrap{margin-bottom:var(--space-md)}.tag-list{display:flex;flex-wrap:wrap;gap:6px;max-height:350px;overflow-y:auto;padding-right:var(--space-xs)}@media(max-width:1100px){.vote-layout{grid-template-columns:1fr;overflow-y:auto}.sidebar-left,.sidebar-right{display:none}}@media(max-width:480px){.app-header{padding:var(--space-sm) var(--space-md)}.header-subtitle{display:none}.vote-buttons{grid-template-columns:1fr}}.login-page{height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 8s ease-in-out infinite;pointer-events:none}.login-page:before{width:400px;height:400px;background:var(--color-primary);top:-100px;right:-100px}.login-page:after{width:350px;height:350px;background:var(--color-accent);bottom:-80px;left:-80px;animation-delay:-4s}.light-theme .login-page:before{opacity:.2}.light-theme .login-page:after{opacity:.15}.login-card{position:relative;z-index:1;width:100%;max-width:420px;padding:var(--space-2xl);background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),var(--shadow-glow);animation:fadeSlideUp .6s ease-out}.login-logo{text-align:center;margin-bottom:var(--space-xl)}.login-logo h1{font-size:var(--font-size-3xl);font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.login-logo p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--space-xs)}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}@media(max-width:480px){.login-card{margin:var(--space-md);padding:var(--space-xl)}}.vote-center,#vote-view{display:flex;flex-direction:column;gap:var(--space-md);height:100%;overflow:hidden}#vote-view.vote-view--hidden{display:none}.list-view{display:flex;flex-direction:column;gap:var(--space-sm);height:100%;overflow:hidden}.list-view.list-view--hidden{display:none}.list-view-search-wrap{flex-shrink:0}.list-items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-xs);padding-right:var(--space-xs)}.list-item{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);display:flex;flex-direction:column;gap:var(--space-xs)}.list-item:hover{background:var(--color-surface);border-color:var(--color-border-focus)}.list-item-main{display:flex;align-items:baseline;gap:var(--space-sm);min-width:0}.list-item-id{font-size:var(--font-size-xs);font-weight:700;color:var(--color-text-muted);flex-shrink:0;font-variant-numeric:tabular-nums}.list-item-text{font-size:var(--font-size-sm);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-meta{display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.list-item-score{font-size:var(--font-size-xs);font-weight:600;color:var(--color-warning);margin-left:auto}.type-toggle{display:flex;gap:var(--space-xs);width:100%;margin-bottom:var(--space-md)}.quote-card{flex:2;background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2xl) var(--space-xl);box-shadow:var(--shadow-md);text-align:left;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:var(--space-md);overflow-y:auto;min-height:0}.quote-card blockquote{font-size:var(--font-size-xl);font-weight:500;line-height:1.6;color:var(--color-text);max-width:600px}.quote-card blockquote code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.9em;background:var(--color-surface);padding:.15em .4em;border-radius:var(--radius-sm);color:var(--color-primary)}.quote-card blockquote strong{font-weight:700;color:var(--color-text)}.quote-card blockquote em{font-style:italic;color:var(--color-text-muted)}.quote-card blockquote del{text-decoration:line-through;opacity:.6}.quote-card blockquote .md-blockquote{border-left:3px solid var(--color-text-muted);padding:.2em .8em;margin:0 0 .1em;background:#ffffff08;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--color-text-muted);font-style:italic}.quote-card blockquote br{display:block;content:"";margin-top:1.2em}.light-theme .quote-card blockquote .md-blockquote{background:#0000000a}.quote-author{font-size:var(--font-size-base);color:var(--color-text-muted);font-style:italic}.quote-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-top:var(--space-sm)}.vote-box{flex:1;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-md);display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);min-height:0}.vote-col-left{display:flex;align-items:stretch;min-height:0}.vote-buttons{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:var(--space-sm);width:100%;height:100%}.vote-col-right{display:flex;flex-direction:column;justify-content:space-between;gap:var(--space-md)}.vote-meta{display:flex;flex-direction:column;gap:var(--space-xs)}.vote-meta-id{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:600;font-variant-numeric:tabular-nums}.vote-score{font-size:var(--font-size-sm);color:var(--color-warning);font-weight:600}.vote-score.score--negative,.list-item-score.score--negative{color:var(--color-error, #f87171)}.vote-counter{font-size:var(--font-size-xs);color:var(--color-text-subtle)}.action-toggles{display:flex;gap:var(--space-sm)}.action-toggle{flex:1;padding:.5rem .6rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);background:var(--color-surface);border:1.5px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);text-align:center}.action-toggle:hover{border-color:var(--color-primary);color:var(--color-text)}.action-toggle.active#btn-fav{background:#facc1526;border-color:#facc1580;color:#facc15}.action-toggle.active#btn-bestof{background:#34d39926;border-color:#34d39980;color:var(--color-success)}.vote-nav{display:flex;gap:var(--space-sm)}.leaderboard-list{display:flex;flex-direction:column;gap:var(--space-sm)}.leader-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.leader-item:hover{background:var(--color-surface)}.leader-rank{font-size:var(--font-size-base);font-weight:700;color:var(--color-text-muted);text-align:center}.leader-content{flex:1;min-width:0}.leader-meta{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:3rem;text-align:center;flex-shrink:0}.leader-text{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.4;margin-bottom:.2rem}.leader-text .md-blockquote{border-left:2px solid var(--color-text-subtle);padding:.1em .5em;margin:0 0 .05em;color:var(--color-text-muted);font-style:italic}.leader-text br{display:block;content:"";margin-top:.6em}.leader-text code{font-size:.85em;background:var(--color-surface);padding:.1em .3em;border-radius:var(--radius-sm);color:var(--color-primary)}.leader-author{font-size:var(--font-size-xs);color:var(--color-text-muted)}.leader-score{display:block;font-size:var(--font-size-sm);font-weight:700;color:var(--color-warning)}.help-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);animation:fadeIn .2s ease}.help-modal-overlay.hidden{display:none}.help-modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:fadeSlideUp .25s ease-out}.help-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.help-modal-header h2{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.help-modal-close{background:none;border:none;font-size:var(--font-size-xl);color:var(--color-text-muted);cursor:pointer;line-height:1;padding:.2rem .4rem;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.help-modal-close:hover{color:var(--color-text)}.help-modal-body{overflow-y:auto;padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-lg)}.help-section h3{font-size:var(--font-size-base);font-weight:700;color:var(--color-text);margin-bottom:var(--space-xs)}.help-section p,.help-section li{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6}.help-section ul{padding-left:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.btn-help{width:2rem;height:2rem;border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted);font-weight:700;font-size:var(--font-size-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.btn-help:hover{background:var(--color-bg-card);color:var(--color-text);border-color:var(--color-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
