*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#0f0f0f;color:#e0e0e0;min-height:100vh}.container{max-width:960px;margin:0 auto;padding:2rem 1rem}h1{font-size:2.5rem;text-align:center}.subtitle{text-align:center;color:#888;margin-bottom:2rem}.drop-zone{border:2px dashed transparent;border-radius:12px;padding:1.5rem;margin-bottom:2rem;transition:all .2s}.drop-zone-active{border-color:#646cff;background:#646cff14}.drop-hint{text-align:center;color:#555;font-size:.85rem;margin-top:.5rem}.generate-form{display:flex;gap:.5rem;margin-bottom:2rem}.generate-form input{flex:1;padding:.75rem 1rem;border-radius:8px;border:1px solid #333;background:#1a1a1a;color:#e0e0e0;font-size:1rem}.generate-form input:focus{outline:none;border-color:#646cff}.generate-form button{padding:.75rem 1.5rem;border-radius:8px;border:none;background:#646cff;color:#fff;font-size:1rem;cursor:pointer;white-space:nowrap}.generate-form button:disabled{opacity:.5;cursor:not-allowed}.upload-button{padding:.75rem 1.5rem;border-radius:8px;border:1px solid #444;background:transparent;color:#ccc;font-size:1rem;cursor:pointer;white-space:nowrap;display:flex;align-items:center}.upload-button:hover{border-color:#646cff;color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#1a1a1a;border-radius:16px;border:1px solid #333;max-width:600px;width:100%;position:relative;overflow:hidden}.modal-preview{padding:1.5rem 1.5rem 0}.modal-preview .meme-image-wrapper{border-radius:8px;overflow:hidden}.modal-controls{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.modal-controls input{padding:.75rem 1rem;border-radius:8px;border:1px solid #333;background:#222;color:#e0e0e0;font-size:1rem;font-weight:700;text-transform:uppercase;text-align:center;letter-spacing:.05em}.modal-controls input:focus{outline:none;border-color:#646cff}.modal-controls input::placeholder{text-transform:none;font-weight:400;letter-spacing:normal}.feedback-row{display:flex;gap:.5rem}.feedback-input{flex:1;text-transform:none!important;font-weight:400!important;text-align:left!important;letter-spacing:normal!important}.feedback-row .btn-secondary{flex:0 0 auto;padding:.75rem 1rem}.modal-buttons{display:flex;gap:.75rem;margin-top:.25rem}.btn-secondary{flex:1;padding:.75rem;border-radius:8px;border:1px solid #444;background:transparent;color:#ccc;font-size:.95rem;cursor:pointer}.btn-secondary:hover{border-color:#646cff;color:#fff}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-primary{flex:1;padding:.75rem;border-radius:8px;border:none;background:#646cff;color:#fff;font-size:.95rem;cursor:pointer;font-weight:500}.btn-primary:hover{background:#535bf2}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.modal-close{position:absolute;top:.75rem;right:.75rem;background:#0009;border:none;color:#aaa;width:2rem;height:2rem;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#fff;background:#000c}.back-button{background:none;border:none;color:#888;font-size:1rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem}.back-button:hover{color:#e0e0e0}.detail-layout{max-width:640px;margin:0 auto}.detail-meme{margin-bottom:1.5rem}.detail-image{border-radius:12px;overflow:hidden;aspect-ratio:auto}.detail-meta{display:flex;gap:1rem;align-items:center;padding:1rem 0}.detail-info{flex:1}.detail-info .meme-prompt{padding:0;font-size:1rem;color:#ccc}.detail-info .meme-author{padding:.25rem 0 0}.vote-controls{display:flex;flex-direction:column;align-items:center;gap:.25rem}.vote-btn{background:none;border:1px solid #333;color:#888;width:2.5rem;height:2rem;border-radius:6px;cursor:pointer;font-size:.9rem}.vote-btn:hover{border-color:#646cff;color:#e0e0e0}.vote-btn.active-up{color:#4ade80;border-color:#4ade80}.vote-btn.active-down{color:#f87171;border-color:#f87171}.vote-score{font-size:1.2rem;font-weight:700;color:#e0e0e0;min-width:2rem;text-align:center}.comments-section h3{font-size:1.1rem;margin-bottom:1rem;color:#ccc}.comments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.comment{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:.75rem 1rem}.comment-header{display:flex;justify-content:space-between;margin-bottom:.35rem}.comment-author{font-size:.85rem;color:#aaa;font-weight:500}.comment-date{font-size:.8rem;color:#666}.comment-body{font-size:.95rem;color:#ddd}.no-comments{color:#666;font-size:.9rem}.comment-form{display:flex;gap:.5rem}.comment-form input{flex:1;padding:.65rem .75rem;border-radius:8px;border:1px solid #333;background:#1a1a1a;color:#e0e0e0;font-size:.95rem}.comment-form input:focus{outline:none;border-color:#646cff}.comment-form button{padding:.65rem 1rem;border-radius:8px;border:none;background:#646cff;color:#fff;font-size:.95rem;cursor:pointer}.comment-form button:disabled{opacity:.5;cursor:not-allowed}.meme-card{transition:all .15s}.meme-card:hover{border-color:#444;transform:translateY(-2px)}.meme-card-new{animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.meme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.meme-card{background:#1a1a1a;border-radius:12px;overflow:hidden;border:1px solid #333}.meme-image-wrapper{position:relative;width:100%;background:#0a0a0a}.meme-image-wrapper img{width:100%;height:auto;display:block}.meme-text{position:absolute;left:0;right:0;text-align:center;font-size:1.5rem;font-weight:900;color:#fff;text-transform:uppercase;text-shadow:2px 2px 0 #000,-2px -2px 0 #000,2px -2px 0 #000,-2px 2px 0 #000;padding:.5rem}.meme-text.top{top:.5rem}.meme-text.bottom{bottom:.5rem}.meme-placeholder{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#222;color:#666;font-size:1.1rem}.meme-prompt{padding:.75rem 1rem;font-size:.9rem;color:#aaa}.meme-footer{display:flex;justify-content:space-between;align-items:center;padding:0 1rem .75rem}.meme-author{font-size:.8rem;color:#666}.meme-score{font-size:.85rem;font-weight:600;color:#888}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.app-header h1{text-align:left}.app-header .subtitle{text-align:left;margin-bottom:0}.user-info{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:#aaa}.logout-button{padding:.4rem .75rem;border-radius:6px;border:1px solid #333;background:transparent;color:#aaa;cursor:pointer;font-size:.85rem}.logout-button:hover{border-color:#646cff;color:#e0e0e0}.login-wrapper{text-align:center;margin-top:3rem}.login-button{display:inline-block;padding:.85rem 2rem;border-radius:8px;background:#646cff;color:#fff;text-decoration:none;font-size:1.1rem;font-weight:500}.login-button:hover{background:#535bf2}.login-note{margin-top:.75rem;color:#666;font-size:.85rem}.tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid #333}.tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;color:#888;font-size:1rem;cursor:pointer}.tab:hover{color:#e0e0e0}.tab-active{color:#e0e0e0;border-bottom-color:#646cff}.template-search{display:flex;gap:.5rem;margin-bottom:1.5rem}.template-search input{flex:1;padding:.65rem .75rem;border-radius:8px;border:1px solid #333;background:#1a1a1a;color:#e0e0e0;font-size:.95rem}.template-search input:focus{outline:none;border-color:#646cff}.template-search button{padding:.65rem 1rem;border-radius:8px;border:none;background:#646cff;color:#fff;cursor:pointer}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.template-card{background:#1a1a1a;border-radius:10px;overflow:hidden;border:1px solid #333;cursor:pointer;transition:all .15s}.template-card:hover{border-color:#646cff;transform:translateY(-2px)}.template-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.template-info{padding:.5rem .75rem}.template-desc{font-size:.8rem;color:#aaa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-uses{font-size:.75rem;color:#666}.template-loading,.template-empty{color:#666;text-align:center;padding:2rem 0}
